热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

fullgc什么时候触发_浅尝Go语言GC

大家好,我是小栈君,因为个人和工作的缘故,所以拖更了一点时间,但是关于拖更的内容小栈君会在后续的时间中补回来,

大家好,我是小栈君,因为个人和工作的缘故,所以拖更了一点时间,但是关于拖更的内容小栈君会在后续的时间中补回来,还希望大家继续支持和关注小栈君。当然,在国内疫情稍微减缓的情况下,小栈君在这里也多说两句,在非常时刻,我们应当保持警惕,清洗手,多通风,避免人群聚集,希望大家平安健康,

闲话不多说,我们直接进入正题,今天给大家分享的事关于Go语言中的GC,本期的分享并没有多少代码可言,都是一些理论知识,希望大家耐心且看完,因为能力有限,所以这边小栈君会尽量用大白话来进行叙述,如有错误之处,还请多多谅解。

GC含义:

对于编程有经验的同学应该都知道GC,他的英文全称是garbage collector ,也就是我们通常所说的垃圾收集器。其实Go语言的垃圾收集器是相对于C++语言有十分重要的改进,针对于开发过C++的同学或是大学的时候学习的C++知识而言的话,我们应该知道在C++语言中创建对象分配空间后需要手动释放,针对于手动释放的情况下,有时候我们很难去进行判断什么时候需要,在编程的难度方面无疑是大大增加了难度。

GO语言GC的发展:

Go语言的GC问题,其实经历过多个版本的迭代,并非一蹴而就,就像我们做编程的一样并非一生下来就会。他也是经历过一定时间的发展史。在1.1版本的时候Go语言采用的STW也就是stop the word,也就是我们常说的标记清扫的方式,在此期间容器是不会执行我们的应用程序,所以也会被人所诟病。在Go语言1.3版本之后,Go语言的团队进行分离了标记和清楚的操作,使用了协程进行并发执行清理,也就是在标记的时候进行Mark STW,sweep的时候并发执行。它所代表的的执行过程大致如下:在进行GC的时候,Go语言会首先停止运行我们的程序,进行递归遍历对象,进行标记,标记完成之后将所有没有引用的对象进行清理。由于标记会进行程序的停止,所以当对象特别多的时候标记和清理的时间就会相对的延长(有可能是几百毫秒),对于大型的项目而言无疑是很难受的。 所以在Go语言的1.5版本中针对于标记和清理算法的改进,引入了三色标记法。从逻辑上进行划分为几大区域,白色区域[未搜索]、灰色区域[正搜索]、黑色区域[已搜索]。 其运行的原理大致如下:

0b12395686f225561100f342db49ed9c.png

程序运行之初,针对于创建的对象都作为白色的标记。然后当我们的GC开始的时候,我们将所有可达的对象都标记为灰色

d79a6977383f9721f0c945eb2da7c3e8.png

然后标记为黑色之后,在以灰色为基点进行可达分析,找到其引用的对象,然后将其引用的对象标记为灰色,自己则变成黑色。

2ec501e1293488b8096aca9ea9df08a4.png

依次进行循环,最终将所有可达的对象标记为黑色,以便于系统区分。

d13f8debe4a8843d2e275e89c2e878c5.png

然后系统再回收白色未标记的对象,释放内存。

7b23da29a7550a0cc85c655449153d96.png

大体的三色标记法的过程就是这样。当然Go语言的团队每次的更新都会对GC算法进行优化,比如在golang1.5版本的时候支持了并发的收集,在1.8的时候已经将STW的时间优化到了100微妙。通常来讲在我们应用程序上一次时间只需要10微妙,而且在1.10版本之后再次减少了GC对于CPU的使用率。

当然值得注意一点的是,和java程序一样程序对于GC的这个动作是自发进行的。在下列的情况下会进行触发GC。一种情况是程序申请内存空间时,发现GC是上次GC的两倍,另一种情况是程序在运行过程中,每2分钟会进行GC的触发。

GC的调优

这里小栈君粗略的讲解一下关于GC的调优吧,第一是我们在程序编写的过程中,要做到尽量的小对象复用,针对于局部变量尽量少去声明,针对于多个小对象的情况我们可以用一个结构体进行包装,方便GC的扫描。其次就是少用string的“+进行字符串的拼接。 最后在go源码中也有对于GC的相关描述:

5621933a7cf131c550ca1fa92177042b.png
982ce557a97f3030e8ea526f72a8b59d.png
3b3364de5714c4586581b17fbd4dfb92.png
89a4dd014322f6a5b5e4cc1502282e16.png
fa0560bb5c6be0535d6fa3cd0e638ffd.png

在runtime包中,这里团队写了关于GC的详细流程,包括GC率和标记方式等等,感兴趣的朋友可以下来看一下,如果英文不是很好的话,可以自行搜索翻译,哈哈哈哈。

好了,今天的浅尝分析go语言的GC就先到这里了,如果你喜欢我的分享,还请记得多多转发,点赞,我是小栈君,我们下期分享再见~,拜了个拜



推荐阅读
  • 一、Hadoop来历Hadoop的思想来源于Google在做搜索引擎的时候出现一个很大的问题就是这么多网页我如何才能以最快的速度来搜索到,由于这个问题Google发明 ... [详细]
  • Android中高级面试必知必会,积累总结
    本文介绍了Android中高级面试的必知必会内容,并总结了相关经验。文章指出,如今的Android市场对开发人员的要求更高,需要更专业的人才。同时,文章还给出了针对Android岗位的职责和要求,并提供了简历突出的建议。 ... [详细]
  • JVM 学习总结(三)——对象存活判定算法的两种实现
    本文介绍了垃圾收集器在回收堆内存前确定对象存活的两种算法:引用计数算法和可达性分析算法。引用计数算法通过计数器判定对象是否存活,虽然简单高效,但无法解决循环引用的问题;可达性分析算法通过判断对象是否可达来确定存活对象,是主流的Java虚拟机内存管理算法。 ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • 本文介绍了Java的集合及其实现类,包括数据结构、抽象类和具体实现类的关系,详细介绍了List接口及其实现类ArrayList的基本操作和特点。文章通过提供相关参考文档和链接,帮助读者更好地理解和使用Java的集合类。 ... [详细]
  • 集合的遍历方式及其局限性
    本文介绍了Java中集合的遍历方式,重点介绍了for-each语句的用法和优势。同时指出了for-each语句无法引用数组或集合的索引的局限性。通过示例代码展示了for-each语句的使用方法,并提供了改写为for语句版本的方法。 ... [详细]
  • 关于CMS收集器的知识介绍和优缺点分析
    本文介绍了CMS收集器的概念、运行过程和优缺点,并解释了垃圾回收器的作用和实践。CMS收集器是一种基于标记-清除算法的垃圾回收器,适用于互联网站和B/S系统等对响应速度和停顿时间有较高要求的应用。同时,还提供了其他垃圾回收器的参考资料。 ... [详细]
  • 本文介绍了操作系统的定义和功能,包括操作系统的本质、用户界面以及系统调用的分类。同时还介绍了进程和线程的区别,包括进程和线程的定义和作用。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 云原生边缘计算之KubeEdge简介及功能特点
    本文介绍了云原生边缘计算中的KubeEdge系统,该系统是一个开源系统,用于将容器化应用程序编排功能扩展到Edge的主机。它基于Kubernetes构建,并为网络应用程序提供基础架构支持。同时,KubeEdge具有离线模式、基于Kubernetes的节点、群集、应用程序和设备管理、资源优化等特点。此外,KubeEdge还支持跨平台工作,在私有、公共和混合云中都可以运行。同时,KubeEdge还提供数据管理和数据分析管道引擎的支持。最后,本文还介绍了KubeEdge系统生成证书的方法。 ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • 本文介绍了C#中生成随机数的三种方法,并分析了其中存在的问题。首先介绍了使用Random类生成随机数的默认方法,但在高并发情况下可能会出现重复的情况。接着通过循环生成了一系列随机数,进一步突显了这个问题。文章指出,随机数生成在任何编程语言中都是必备的功能,但Random类生成的随机数并不可靠。最后,提出了需要寻找其他可靠的随机数生成方法的建议。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • Tomcat/Jetty为何选择扩展线程池而不是使用JDK原生线程池?
    本文探讨了Tomcat和Jetty选择扩展线程池而不是使用JDK原生线程池的原因。通过比较IO密集型任务和CPU密集型任务的特点,解释了为何Tomcat和Jetty需要扩展线程池来提高并发度和任务处理速度。同时,介绍了JDK原生线程池的工作流程。 ... [详细]
author-avatar
郝泓帥_169
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有