Go语言小知识之append()函数

本文探讨了Go语言中内置的append()函数,详细解释了当slice需要扩容时的机制。通过实验代码展示,当slice容量不足时,不是简单增加到刚好能容纳新item,而是会扩展为原来的两倍,提供了对Go语言内存管理和性能优化的见解。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

内置的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

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值