Go 中內建的追加函數透過建立一個新的底層陣列來將元素追加到切片中,複製現有元素,並附加新元素。如果原始切片和追加函數中使用的切片共享相同的底層數組,則對任一切片所做的更改將反映在兩個切片中。
考慮以下程式碼片段:
func someFunc(A []int) int { ... tempA := A // copy the slice by value ... newArr = remove(tempA, i) ... } func remove(slice []int, s int) []int { return append(slice[:s], slice[s+1:]...) }
這裡,someFunc 函數接受一個切片 A 並建立它的一個副本,稱為 tempA。然後,remove 函數對 tempA 執行追加函數,以刪除索引 s 處的元素。
由於 tempA 切片最初引用與 A 相同的底層數組,因此對 tempA 所做的修改(透過追加函數)也將被刪除。反映在A。這是因為append函數建立了一個新的底層數組並將現有元素複製到其中。由於 A 和 tempA 共享相同的底層數組,因此對其中一個所做的任何更改也會傳播到另一個。
由於切片的內部實作方式,這種行為在 Go 中是預期的:
要避免這種共享引用行為,您可以建立一個新切片並明確複製元素,如下所示:
tempA := make([]int, len(A)) copy(tempA, A)
以上是為什麼在 Go 中附加到切片副本有時會修改原始資料?的詳細內容。更多資訊請關注PHP中文網其他相關文章!