首頁 > 後端開發 > Golang > 為什麼 Go 的切片和映射在添加元素作為函數參數時表現不同?

為什麼 Go 的切片和映射在添加元素作為函數參數時表現不同?

DDD
發布: 2024-12-23 10:12:36
原創
185 人瀏覽過

Why Do Go's Slices and Maps Behave Differently When Adding Elements as Function Parameters?

參數傳遞中的切片與映射:深入探討

在 Go 中,切片和映射都有引用類型的特徵。然而,在參數中添加新元素時,它們的行為有所不同。雖然新增到映射的新元素會自動反映在參數中,但新增到切片的新元素會在參數中「丟棄」。

實現差異

這種差異源自於這些類型的實現方式。映射被實作為指向內部哈希映射資料結構的指標。當新元素加入映射時,哈希映射資料結構會更新,但底層指標保持不變。這確保了對映射的所有引用都指向相同的底層資料結構。

另一方面,切片被實作為儲存指向後備數組的指標以及切片長度和容量的結構。當將新元素新增至切片時,需要建立一個具有更新長度的新切片頭,如果需要,也可能需要建立新的後備陣列。這個新的切片頭被分配給指向它的變量,但原始切片頭保持不變。

以值傳遞

另一個導致觀察到的行為的因素是 Go 的值傳遞語意。當映射傳遞給函數時,函數會接收到映射指標的副本。透過此副本對映射進行的任何修改也會影響原始映射,因為它們都指向相同的底層資料結構。

當切片傳遞給函數時,函數會收到切片標頭的副本。切片的修改將建立一個具有更新的長度和容量的新切片頭,但原始切片頭不會受到影響。因此,參數將看不到函數內所做的變更。

對 API 一致性的影響

在此上下文中切片和映射的不同行為可能會給開發人員帶來潛在的陷阱,特別是那些剛接觸 Go 的人。這些引用類型的 API 看起來不一致,因為其中一種的行為符合預期的值修改,但另一種則不然。

可能的解決方案

為了實現 API 行為的一致性,可以使切片的行為類似於指向底層資料結構的指針,類似於映射。然而,這種方法很少使用,並且缺乏語言支援。相反,常見的做法是在新增元素時傳回一個新切片。這可確保呼叫者收到切片的更新版本。

以上是為什麼 Go 的切片和映射在添加元素作為函數參數時表現不同?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板