陣列與切片:元素存取的速度比較
在Go 中,陣列和切片是常用的資料結構,用於儲存有序集合元素。兩者之間的一個顯著差異是它們的性能特徵。
在存取元素時,存取陣列中的元素預計會比存取切片中的元素更快。這是因為切片代表底層數組的視圖,存取其元素可能涉及額外的間接層級。
但是,最近的基準測試顯示了令人驚訝的結果。比較本地數組和切片時,結果顯示本地切片存取元素的速度明顯快於本地數組。
結果分析
檢查彙編程式碼對於本地數組和本地切片,一個關鍵的區別變得顯而易見。數組版本在每次數組存取時都會從記憶體重複載入數組 (a) 的位址。
LEAQ "".a+1000(SP),BX
相較之下,切片版本在最初從記憶體載入切片資料後僅在暫存器上進行計算。
LEAQ (DX)(SI*1),BX
記憶體存取模式的這種差異可能解釋了本地切片的效能優勢。透過避免重複的記憶體載入來存取數組的基底位址,切片可以受益於更快的元素存取。
此外,陣列版本會呼叫 runtime.duffcopy 例程,而切片版本則不會。 Duffcopy 是一個針對批次記憶體複製而最佳化的彙編例程,它在陣列版本中的使用可能會進一步導致其效能下降。
以上是Go 中的陣列與切片:為什麼本地切片元素存取速度更快?的詳細內容。更多資訊請關注PHP中文網其他相關文章!