日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 人文社科 > 生活经验 >内容正文

生活经验

Go 知识点(06)— for range 切片并对切片进行 append 不会造成死循环

發布時間:2023/11/28 生活经验 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Go 知识点(06)— for range 切片并对切片进行 append 不会造成死循环 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

想想下面代碼會發生什么?

func main() {a := []int{1, 2, 3}for _, v := range a {a = append(a, v)fmt.Println("len(a)=", len(a))}fmt.Printf("a is %#v", a)
}

會造成死循環嗎? 答案是:不會。

對于 Go 中的 for ... range 而言,實際上在循環之前就已經獲取了切片的長度,然后再執行固定次數的循環,所以上面代碼打印結果是:

len(a)= 4
len(a)= 5
len(a)= 6
a is []int{1, 2, 3, 1, 2, 3}

對于切片的 for range ,它的底層代碼是:

for_temp := range
len_temp := len(for_temp)
for index_temp = 0; index_temp < len_temp; index_temp++ {value_temp = for_temp[index_temp]index = index_tempvalue = value_temporiginal body
}

可以看到,在遍歷之前就已經獲取的切片的長度 len_temp := len(for_temp),所以遍歷的次數不會隨著切片的變化而變化,上面的代碼自然不會是死循環了。

上面代碼會被 Go 當做以下代碼執行:

func main() {a := []int{1, 2, 3}for_temp := alen_temp := len(for_temp)for index_temp := 0; index_temp < len_temp; index_temp++ {value_temp := for_temp[index_temp]_ = index_tempvalue := value_tempa = append(a, value)fmt.Println("len(a)=", len(a))}fmt.Printf("a is %#v", a)
}

參考:

https://segmentfault.com/a/1190000023477520

https://blog.csdn.net/lengyue1084/article/details/108124495

總結

以上是生活随笔為你收集整理的Go 知识点(06)— for range 切片并对切片进行 append 不会造成死循环的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。