原創(chuàng)文章轉(zhuǎn)載請(qǐng)注明出處
go的數(shù)組元素可以通過(guò) 索引(位置)來(lái)讀?。ɑ蛘咝薷模?,索引從 0 開始,第一個(gè)元素索引為 0,第二個(gè)索引為 1,以此類推。
可以通過(guò)for結(jié)構(gòu)遍歷數(shù)組,實(shí)現(xiàn)以下功能:
- 通過(guò) for 初始化數(shù)組項(xiàng)
- 通過(guò) for 打印數(shù)組元素
- 通過(guò) for 依次處理元素
for結(jié)構(gòu)的基本使用方式如下:
package main
import "fmt"
func main() {
var arr1 [5]int
for i:=0; i < len(arr1); i++ {
arr1[i] = i * 2
}
for i:=0; i < len(arr1); i++ {
fmt.Printf("Array at index %d is %d\n", i, arr1[i])
}
}
for 循環(huán)中的條件非常重要:i < len(arr1),如果寫成 i <= len(arr1) 的話會(huì)產(chǎn)生越界錯(cuò)誤。所以,我們一般用關(guān)鍵字range來(lái)避免這種錯(cuò)誤。
for i, v:= range arr1 {
...
}
當(dāng)然以上兩種 for 結(jié)構(gòu)對(duì)于切片(slices)來(lái)說(shuō)也同樣適用。
需要注意的問題來(lái)了,通過(guò)range遍歷得到的value是值拷貝。
type s struct {
i int
}
func main() {
m := make([]s, 0)
m = append(m, s{i: 0})
m = append(m, s{i: 1})
m = append(m, s{i: 2})
for _, e := range m { //e是值拷貝
e.i = 3
}
for _, x := range m {
fmt.Printf("%v\n", x.i)
}
}
上述代碼第一個(gè)for循環(huán)中的e是原值的拷貝,所以e.i = 3并沒有修改原數(shù)組中的元素,所以輸出的結(jié)果如下:
0
1
2
如果非要在使用range遍歷的過(guò)程中修改數(shù)組內(nèi)容,那么還是要用下標(biāo)訪問數(shù)組元素。
type s struct {
i int
}
func main() {
m := make([]s, 0)
m = append(m, s{i: 0})
m = append(m, s{i: 1})
m = append(m, s{i: 2})
for index := range m { //獲取索引
m[index].i = 3 //通過(guò)下標(biāo)獲取元素進(jìn)行修改
}
for _, x := range m {
fmt.Printf("%v\n", x.i)
}
}
輸出
3
3
3
我是咕咕雞,一個(gè)還在不停學(xué)習(xí)的全棧工程師。
熱愛生活,喜歡跑步,家庭是我不斷向前進(jìn)步的動(dòng)力。