go實現(xiàn)for range迭代時修改值的操作
for range的val不能直接修改
因為地址不同
package main
import "fmt"
func main() {
x := make([]int, 3)
x[0], x[1], x[2] = 1, 2, 3
for i, val := range x {
fmt.Println(&x[i], "vs.", &val)
}
}
//輸出
0x416020 vs. 0x41602c
0x416024 vs. 0x41602c
0x416028 vs. 0x41602c
補充:GO語言使用range遍歷數(shù)組,值不被改變(避開range坑)
首先GO語言遍歷數(shù)組兩種方式
一種是
for i:=0;i<len;i++{}
這種方式,就是如果在循環(huán)中更改數(shù)組的值,則會更改到原數(shù)組的值。沒有進(jìn)行數(shù)組值的復(fù)制
第二種方式
也是主要介紹的就是range遍歷數(shù)組
for _,num :=range arr{}
這種方式遍歷數(shù)組,會將遍歷的數(shù)組的每一個元素進(jìn)行復(fù)制,通過使用復(fù)制的值,進(jìn)行for循環(huán)的內(nèi)容,在for循環(huán)中進(jìn)行更改值,不會影響原數(shù)組的值
舉例說明:
func (student Student) rename() {
student.name = "xiang"
}
func main() {
var a []int
a = []int{1, 2, 3, 4, 5, 6, 7, 8}
for i := 0; i < len(a); i++ {
a[i] = 0
}
fmt.Println(a)
}
此時用的是for i:=0;i<len;i++循環(huán)方式,,根據(jù)輸出,可以判斷,修改的是原數(shù)組。

使用Range遍歷數(shù)組
func main() {
var a []int
a = []int{1, 2, 3, 4, 5, 6, 7, 8}
for _, num := range a {
num = 0
fmt.Print(num, " ")
}
fmt.Println(a)
}

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章
在Go語言單元測試中解決HTTP網(wǎng)絡(luò)依賴問題
在 Go 語言中,我們需要找到一種可靠的方法來測試 HTTP 請求和響應(yīng),本文將探討在 Go 中進(jìn)行 HTTP 應(yīng)用測試時,如何解決應(yīng)用程序的依賴問題,以確保我們能夠編寫出可靠的測試用例,需要的朋友可以參考下2023-07-07
一文帶你了解Golang中interface的設(shè)計與實現(xiàn)
本文就來詳細(xì)說說為什么說?接口本質(zhì)是一種自定義類型,以及這種自定義類型是如何構(gòu)建起?go?的?interface?系統(tǒng)的,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-01-01
Go語言常見錯誤之濫用getters/setters誤區(qū)實例探究
在Go語言編程中,恰如其分地使用getters和setters是至關(guān)重要的,過度和不適當(dāng)?shù)厥褂盟鼈兛赡軐?dǎo)致代碼冗余、可讀性差和封裝不當(dāng),在本文中,我們將深入探討如何識別濫用getter和setter的情況,以及如何采取最佳實踐來避免這些常見的Go錯誤2024-01-01
golang?chan傳遞數(shù)據(jù)的性能開銷詳解
這篇文章主要為大家詳細(xì)介紹了Golang中chan在接收和發(fā)送數(shù)據(jù)時因為“復(fù)制”而產(chǎn)生的開銷,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解下2024-01-01

