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

闲话不多说,我们直接进入正题,今天给大家分享的事关于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版本中针对于标记和清理算法的改进,引入了三色标记法。从逻辑上进行划分为几大区域,白色区域[未搜索]、灰色区域[正搜索]、黑色区域[已搜索]。

其运行的原理大致如下:

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

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

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

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

大体的三色标记法的过程就是这样。当然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的相关描述:









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

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

本文由博客一文多发平台 OpenWrite 发布!

浅尝Go语言GC的更多相关文章

  1. 浅尝ECMAScript6

    浅尝ECMAScript6 简介 ECMAScript6 是最新的ECMAScript标准,于2015年6月正式推出(所以也称为ECMAScript 2015),相比于2009年推出的es5, es6 ...

  2. Python图形界面开发编程:wxPython(浅尝篇)

    Python 提供了多个图形开发界面的库,几个常用 Python GUI 库如下: Tkinter: Tkinter 模块(Tk 接口)是 Python 的标准 Tk GUI 工具包的接口 .Tk 和 ...

  3. 浅入浅出 Go 语言接口的原理

    浅入浅出 Go 语言接口的原理 接口是 Go 语言的重要组成部分,它在 Go 语言中通过一组方法指定了一个对象的行为,接口 interface 的引入能够让我们在 Go 语言更好地组织并写出易于测试的 ...

  4. 浅谈C语言中的强符号、弱符号、强引用和弱引用

    摘自http://www.jb51.net/article/56924.htm 浅谈C语言中的强符号.弱符号.强引用和弱引用 投稿:hebedich 字体:[增加 减小] 类型:转载 时间:2014- ...

  5. 浅尝key-value数据库(二)——MongoDB的优与劣

    浅尝key-value数据库(二)——MongoDB的优与劣 MongoDB的名字取自英文单词"humongous"的中间五个字母,是一个C++开发的基于分布式文件存储的数据库开源 ...

  6. 浅尝key-value数据库(三)——MongoDB的分布式

    浅尝key-value数据库(三)——MongoDB的分布式 测试了单机MongoDB的随机读和写入性能,这一节来讲一讲MongoDB的分布式. MongoDB的分布式分成两种,一种是Replicat ...

  7. 浅尝key-value数据库(一)——一览NoSQL

    浅尝key-value数据库(一)——一览NoSQL 最近由于一个项目的关系,研究了一下key-value数据库这个最近很火的概念.本系列从项目需求的角度分析并测试了几个key-value数据库的性能 ...

  8. 浅谈Java语言环境搭建-JDK8

    title: 浅谈Java语言环境搭建-JDK8 blog: CSDN data: Java学习路线及视频 1.What's the JDK,JRE JDK(Java Development Kit ...

  9. 浅尝装饰器和AOP

    [写在前面] 参考文章:https://www.cnblogs.com/huxi/archive/2011/03/01/1967600.html[从简单的例子入手进行讲解,由浅入深,很到位] 装饰器部 ...

随机推荐

  1. Angular 1 深度解析:脏数据检查与 angular 性能优化

    TL;DR 脏检查是一种模型到视图的数据映射机制,由 $apply 或 $digest 触发. 脏检查的范围是整个页面,不受区域或组件划分影响 使用尽量简单的绑定表达式提升脏检查执行速度 尽量减少页面 ...

  2. 安装docker,docker-compose,Harbor

    一.docker安装 1.删除旧版本和相关依赖 yum remove docker \ docker-client \ docker-client-latest \ docker-common \ d ...

  3. iview的render函数使用

    render渲染函数详解 https://www.cnblogs.com/weichen913/p/9676210.html iview表格的render函数作用是自定义渲染当前列,权限高于key,所 ...

  4. js的变量——基本类型保存在栈中,引用类型保存在堆中

    javascript的基本类型:Undefined,Null,Boolean,Number,String 引用类型:Object,Array,Function 基本类型值在内存中占据固定大小,被保存在 ...

  5. 01 极简Linux操作系统发展历史

    Unix操作系统的诞生 1965 年之前的时候,电脑并不像现在一样普遍,它可不是一般人能碰的起的,除非是军事或者学院的研究机构,而且当时大型主机至多能提供30台终端(30个键盘.显示器),连接一台电脑 ...

  6. [IOI1994] 时钟 - 搜索

    考虑九个安排在 \(3 \times 3\) 矩阵中的时钟,每个时钟只会指向 \(3,6,9,12\) 点.有 \(9\) 种操作方式,每种操作方式规定了其固定的操作对象集合,将这几个时钟都往后拨 \ ...

  7. 还在使用集合类完成这些功能?不妨来看看 Guava 集合类!!!

    日常开发中,小黑哥经常需要用到 Java 提供集合类完成各种需求.Java 集合类虽然非常强大实用,但是提供功能还是有点薄弱. 举个例子,小黑哥最近接到一个需求,从输入一个文档中,统计一个关键词出现的 ...

  8. JAVA校内赛

    第一题: 问题描述 在计算机存储中,15.125GB是多少MB?答案提交 这是一道结果填空的题,你只需要算出结果后提交即可.本题的结果为一个整数,在提交答案时只填写这个整数,填写多余的内容将无法得分. ...

  9. LCN解决分布式事务原理解析+项目实战(原创精华版)

    写在前面: 原创不易,如果觉得不错推荐一下,谢谢! 由于工作需要,公司的微服务项目需解决分布式事务的问题,且由我进行分布式事务框架搭建和整合工作. 那么借此机会好好的将解决分布式事务的内容进行整理一下 ...

  10. 【JDK】JDK源码分析-HashMap(2)

    前文「JDK源码分析-HashMap(1)」分析了 HashMap 的内部结构和主要方法的实现原理.但是,面试中通常还会问到很多其他的问题,本文简要分析下常见的一些问题. 这里再贴一下 HashMap ...