【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停顿的信息别忘了在本站进行查找喔。