1 回答

TA貢獻1843條經(jīng)驗 獲得超7個贊
您不將結果存儲append()
在“原始”中slice
,因為您使用短變量聲明而不是賦值:
slice := append(slice, i)
短變量聲明(因為它與原始slice變量位于不同的塊中)創(chuàng)建一個新變量(隱藏外部slice),并在循環(huán)內打印這個新變量。因此,每次追加的結果僅在循環(huán)體內可見,并在迭代結束時丟失。而是使用賦值:
slice = append(slice, i)
但是,當您這樣做時,您將得到一個無限循環(huán),因為您的循環(huán)條件是i < len(slice),并且slice在每次迭代中都會增長。
相反,你應該這樣做(評估len(slice)一次并存儲它):
for i, length := 0, len(slice); i < length; i++ {
? ? slice = append(slice, i)
? ? fmt.Println(slice)
}
輸出將是(在Go Playground上嘗試):
[5 4 3 2 1 0]
[5 4 3 2 1 0 1]
[5 4 3 2 1 0 1 2]
[5 4 3 2 1 0 1 2 3]
[5 4 3 2 1 0 1 2 3 4]
[5 4 3 2 1 0 1 2 3 4]
請注意,如果使用 ,您將得到相同的結果for range,因為它只計算切片一次:
for i := range slice {
? ? slice = append(slice, i)
? ? fmt.Println(slice)
}
在Go Playground上試試這個。
- 1 回答
- 0 關注
- 121 瀏覽
添加回答
舉報