登录
首页 >  Golang >  Go问答

下面的两个 go 代码有什么区别,为什么使用如此不同的内存

来源:stackoverflow

时间:2024-04-10 09:39:27 269浏览 收藏

目前golang学习网上已经有很多关于Golang的文章了,自己在初次阅读这些文章中,也见识到了很多学习思路;那么本文《下面的两个 go 代码有什么区别,为什么使用如此不同的内存》,也希望能帮助到大家,如果阅读完后真的对你学习Golang有帮助,欢迎动动手指,评论留言并分享~

问题内容

代码a:

maxcnt := 1000000
wg := sync.waitgroup{}
    wg.add(maxcnt)
    for i:=0; i

代码b:

MaxCnt := 1000000
wg := sync.WaitGroup{}
    wg.Add(MaxCnt)
    for i:=0; i

代码 a 使用大约 460mb 内存,代码 b 使用几 kb 内存,它们都 go func 10k 次。我想知道为什么?


解决方案


他们不是做一万次,而是做一百万次。第一个在等待 1 毫秒的同时,创建了数千个 goroutine,每个 goroutine 都有 2K 堆栈。如果这需要 460M,那么在一切完成后,您将拥有大约 230K 活动并发 goroutine。第二个,虽然它创建了相同数量的 goroutine,但它们很快终止,从而使活动的并发 goroutine 数量保持在较低水平。

终于介绍完啦!小伙伴们,这篇关于《下面的两个 go 代码有什么区别,为什么使用如此不同的内存》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布Golang相关知识,快来关注吧!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>