go切片扩容遇到的一些问题

go切片扩容遇到的一些问题,第1张

大家都知道切片的扩容规则:

如果原Slice容量小于1024,则新Slice容量将扩大为原来的2倍如果原Slice容量大于等于1024,则新Slice容量将扩大为原来的1.25倍

当我去实践的时候,发现有一些怪异

如下:

func main() {
	slice := make([]int, 1024)
	slice = append(slice, 1)
	fmt.Println(len(slice), cap(slice)) // 1025 1344
}

超过1024,不是扩容1.25吗,那cap(slice)不应该是1280的嘛,但我电脑上却输出1344

这不应该啊

我看了下int占的字节

fmt.Println(unsafe.Sizeof(int(1))) // 4

更疑惑了

我的电脑是64位 *** 作系统啊,int默认不应该是int64,占8字节吗

打开cmd,输入 go env 看了下配置

发现 GOARCH的值是 386,386就是32位

解决如下:

在cmd中输入

go env -w GOARCH=amd64

就改成64位了,在来看下上面那段代码的输出,cap(slice)就变成了1280,符合扩容1.25倍的规则,完美!

没问题后,我又验证了一下:把初始容量改为1280

func main() {
	slice := make([]int, 1280)
	slice = append(slice, 1)
	fmt.Println(len(slice), cap(slice)) // 1281 1696
}

结果它又出问题了,1280*1.25=1600,它却输出1696????

这里涉及到了切片扩容的源码,除了上面熟悉的扩容规则,还涉及到内存对齐

这篇文章讲解切片扩容机制十分详细,推荐给大家

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/993859.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-21
下一篇 2022-05-21

发表评论

登录后才能评论

评论列表(0条)

保存