下面的两个Go代码有什么不同,为什么使用了这么多不同的内存?
代码1:
package main
import "fmt"
func main() {
var a []int
for i := 0; i < 1000000; i++ {
a = append(a, i)
}
fmt.Println(len(a))
}
代码2:
package main
import "fmt"
func main() {
a := make([]int, 0, 1000000)
for i := 0; i < 1000000; i++ {
a = append(a, i)
}
fmt.Println(len(a))
}
这两段代码的不同之处在于内存分配的方式和内存使用情况。
代码1中,使用了切片的默认初始化方式,即var a []int
,这样的切片长度为0,容量为0。在循环中通过append
函数向切片中添加元素,每次添加元素时,如果切片的容量不足,会重新分配更大的内存空间,并将原有的元素复制到新的内存空间中。这种方式会导致频繁的内存分配和复制操作,消耗较多的内存和时间。
代码2中,使用了make
函数初始化切片,指定了切片的长度为0,容量为1000000,即a := make([]int, 0, 1000000)
。在循环中通过append
函数向切片中添加元素,如果切片的容量不足,会自动扩容,但是由于初始容量已经足够,不需要频繁的内存分配和复制操作,因此效率更高,消耗的内存也较少。
综上所述,代码2使用了更少的内存,因为它避免了频繁的内存分配和复制操作。在处理大量数据时,尽量预先分配足够的内存空间,可以提高程序的性能和效率。
云+社区技术沙龙[第28期]
云+社区技术沙龙[第7期]
云+社区技术沙龙[第16期]
云+未来峰会
DB TALK 技术分享会
云+社区技术沙龙[第4期]
技术创作101训练营
Techo Day 第二期
Hello Serverless 来了
云+社区技术沙龙[第9期]
领取专属 10元无门槛券
手把手带您无忧上云