首页>>后端>>Golang->go语言gc停顿,go语言运行

go语言gc停顿,go语言运行

时间:2024-01-22 本站 点击:14

【golang】内存逃逸常见情况和避免方式

1、在方法内把局部变量指针返回,被外部引用,其生命周期大于栈,则溢出。发送指针或带有指针的值到channel,因为编译时候无法知道那个goroutine会在channel接受数据,编译器无法知道什么时候释放。

go的垃圾回收算法

1、总来的来说也是为了提高垃圾回收的效率,并且尽可能的减少STW的时间。 了解下来,与java的分代回收相比,golang中的回收算法理解起来更加简单一些。

2、调整 GOGC 只会改变线性常量(以及使用的额外内存量)。为了防止在扫描大型对象时出现长时间的暂停,并提高并行性,垃圾收集器将大于 maxObletBytes 的对象的扫描作业分解为最多 maxObletBytes 的 oblets 。

3、在x8664环境上,golang管理的有效的程序虚拟地址空间实质上只有48位。在mheap中有一个pages pageAlloc成员用于管理golang堆内存的地址空间。

Golang什么时候会触发GC

1、其实在Golang 内部所有的GC都是通过 gcStart() 函数,然后指定一个 gcTrigger 的参数来开始的,而手动触发指定的条件值为 gcTriggerCycle 。 gcStart 是一个很复杂的函数,有兴趣的可以看一下源码实现。

2、Minor GC触发条件:当Eden区满时,触发Minor GC。

3、young GC:当young gen中的eden区分配满的时候触发。注意young GC中有部分存活对象会晋升到old gen,所以young GC后old gen的占用量通常会有所升高。

4、在go http每一次go serve(l)都会构建Request数据结构。在大量数据请求或高并发的场景中,频繁创建销毁对象,会导致GC压力。解决办法之一就是使用对象复用技术。在http协议层之下,使用对象复用技术创建Request数据结构。

5、Golang语言的标记清除垃圾回收算法,为了防止GC扫描时内存变化引起的混乱。那么就需要 STW,即Stop The World。具体在Golang语言中是指,在GC时先停止所有goroutine。

go语言gc停顿的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于go语言运行、go语言gc停顿的信息别忘了在本站进行查找喔。


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:/Golang/133827.html