Go 中的動態陣列分配:使用切片
與其他程式語言不同,Go 陣列不是在運行時直接分配的。當需要動態確定數組的大小時,這可能會帶來挑戰。
固定大小數組的困境
考慮以下嘗試分配的代碼具有運行時大小的數組:
n := 1 var a [n]int
此代碼將導致錯誤,因為Go 要求數組大小為編譯時已知的常數表達式。
解:切片
解決這個困境的方法是使用切片而不是陣列。與數組不同,切片允許在運行時確定其大小。內建函數 make() 可用於建立具有指定長度和容量的切片:
s := make([]int, n, 2*n)
在此範例中,s 是初始長度為 n 且容量為整數的切片2*n 個。這意味著切片在需要重新分配之前最多可以容納 2*n 個元素。
為什麼不使用陣列?
Go 為何不使用陣列?允許直接分配具有運行時大小的陣列。背後的基本原理是,在大多數情況下,Go 更喜歡切片而不是陣列。切片提供了動態調整大小的靈活性,並避免了陣列附帶的明確記憶體管理。
因此,Go 中推薦的方法是使用切片,它既提供了運行時分配的靈活性,又提供了簡單性自動記憶體管理。
以上是當編譯時數組大小未知時,Go 如何處理動態數組分配?的詳細內容。更多資訊請關注PHP中文網其他相關文章!