Go語言小知識之append()函式

zxh0發表於2017-04-13

內建的append()函式,給slice追加一個item。如果這個slice還有空閒容量(cap(s) > len(s)),則直接進行追加。否則,先對slice進行擴容,然後再進行追加。上述這些在append()函式的文件裡有詳細的說明,但是文件並沒有說擴容是如何進行的,所以下面用一段程式碼做一個試驗:

package main

func main() {
    s := []int{}; println(cap(s)) // 0
    s = appendN(s, 1); println(cap(s)) // 2
    s = appendN(s, 2); println(cap(s)) // 4
    s = appendN(s, 4); println(cap(s)) // 8
    s = appendN(s, 8); println(cap(s)) // 16
    s = appendN(s, 16); println(cap(s)) // 32
    s = appendN(s, 32); println(cap(s)) // 64
    s = appendN(s, 64); println(cap(s)) // 128
    s = []int{1,2,3}; println(cap(s)) // 3
    s = appendN(s, 2); println(cap(s)) // 8
}

func appendN(s []int, n int) []int {
    for i := 0; i < n; i++ {
        s = append(s, 0)
    }
    return s
}

由此可知,(至少就上面的程式碼而言)每次需要擴容的時候,容量並不是簡單增長到足夠容納新的item,而是會被進一步擴充成2n

相關文章