牛皮了!世界级调优大师以上古传承之魔法,彻底揭开GC的秘密

简介: 计算机的进步,特别是硬件的发展之快总是让我们感到惊讶。在这波不断向前涌动的洪流中,技术领域的浮沉也愈发激烈。本书涉及的垃圾回收(Garbage Collection, GC)与其说是理论,其实更偏向技术层面,然而它却有着令人吃惊的漫长历史。GC在计算机发展的激流中没有浮起,也没有沉下。直到1995年Java发布,因为其内藏GC,人们才开始意识到GC的作用。

开篇水一水

计算机的进步,特别是硬件的发展之快总是让我们感到惊讶。在这波不断向前涌动的洪流中,技术领域的浮沉也愈发激烈。本书涉及的垃圾回收(Garbage Collection, GC)与其说是理论,其实更偏向技术层面,然而它却有着令人吃惊的漫长历史。GC在计算机发展的激流中没有浮起,也没有沉下。直到1995年Java发布,因为其内藏GC,人们才开始意识到GC的作用。

追溯Lisp语言的秘史我们会发现,GC这种让已经无法利用的内存实现自动再利用(可能称为“内存资源回收”更恰当)的技术,是于Lisp的设计开始约1年后,也就是1959年的夏天首次出现的。实现GC的是一个叫D. Edwards 的人。至今已经经过了60多年的漫长岁月。

如果看看某本教科书中的一节或者读读几篇论文 就能明白GC是什么东西, 那么或许就不需要这本书了,但GC并没有那么简单。

因为Java的出现,人们开始普遍认识到GC的可贵,自此多数的脚本语言都具备了GC。看到这种情形,我这个跟GC拉拉扯扯了近40年的人真是感慨万千。虽然没有什么切实的根据,但是我一直认为,具备GC的语言要比不具备GC的同等语言生产效率高百分之三十。

既然话说到这里了,我就再介绍一下我的个人看法吧。实际上,GC相当于虚拟内存。一般的虚拟内存技术是在较小的物理内存的基础上,利用辅助存储创造一片看 上去很大的“虚拟”地址空间。也就是说,GC是扩大内存空间的技术,因此我称其为空间性虚拟存储。这样一来,GC就成了永久提供一次性存储空间的时间轴方向的时间性虚拟存储。神奇的是,比起称为“垃圾回收”,把GC称为“虚拟内存"令人感觉其重要了许多。当初人们根据计算机体系结构开发了许多关于空间性虚拟存储的支持,所以大部分的计算机都标配了空间性虚拟存储。只要硬件支持,GC性能就能稳步提升,然而现实情况是几乎没有支持GC的硬件,这不能不令人感到遗憾。

要说本书与涵盖面较广的GarbageCollection有什么不同,那就是本书涉及的面不那么广,但“算法篇”中对GC的基础内容进行了详实的讲解。另外,“实现篇”是本书的一大特色,其中解读了实际的GC代码。总体而言,本书作为一本教科书有着教育和现实意义。

那么,下面咱们就从目录、主要包括的内容和总结三部分给大家进行GC的拓展学习,希望大家能够喜欢!!

目录:

由于篇幅限制小编,小编只在这里给大家展示目录及部分内容,有需要完整文档的程序猿(媛)可以点击此处来获取就可以了!

算法篇:共9章

1学习GC之前:本章中将为各位说明GC中的基本概念。

2 GC标记-清除算法:世界上首个值得纪念的GC算法是GC标记-清除算法(Mark Sweep GC)”。自其问世以来,一直到半个世纪后的今天,它依然是各种处理程序所用的伟大的算法。

3引用计数法:GC原本是一种“释放怎么都无法被引用的对象的机制”。那么人们自然而然地就会想到,可以让所有对象事先记录下“有多少程序引用自己"。让各对象知道自己的“人气指数",从而让没有人气的对象自己消失,这就是引用计数法(Reference Counting),它是George E. Collins于1960年钻研出来的。

4 GC复制算法:GC复制算法(Copying GC )是Marvin L. Minsky在1963年研究出来的算法。说得简单点,就是只把某个空间里的活动对象复制到其他空间,把原空间里的所有对象都回收掉。这是一个相当大胆的算法。在此,我们将复制活动对象的原空间称为From空间,将粘贴活动对象的新空间称为To空间。

5 GC标记-压缩算法:GC标记-压缩算法(Mark Compact GC )是将GC标记-清除算法与GC复制算法相结合的产物,因此我们要以第2章和第4章的内容为前提来向大家说明。

6保守式GC:在此之前,我们在“算法篇”中介绍了很多种GC算法。而要想在处理程序中实现这些算法,处理程序的开发者就必须首先选择GC的种类。这里的种类指的是“保守式GC"和“准确式GC"

7分代垃圾回收:分代垃圾回收(Generational GC )在对象中导入了“年龄”的概念,通过优先回收容易成为垃圾的对象,提高垃圾回收的效率。

8增量式垃圾回收:增量式垃圾回收(Incremental GC )是一种通过逐渐推进垃圾回收来控制mutator最大暂停时间的方法。

9 RC Immix算法:本章将为大家介绍2013年由Rifat Shahriyar等人开发的RC Immix算法(ReferenceCounting Immix )27]。

实现篇:共4章

10 Python的垃圾回收:本章中将为大家解说Python的垃圾回收是如何实现的。

11 DalvikVM的垃圾回收:本章将为大家介绍DalvikVM的垃圾回收。说到DalvikVM大家或许不熟悉,但如果说“Google手机”上搭载的VM,大家就该有印象了吧。

12 Rubinius的垃圾回收:本章将为大家讲解Rubinius这种语言处理程序的垃圾回收。Rubinius 属于为数不多的Ruby处理系统中的一种。

13 V8的垃圾回收:本章中将为大家讲解JavaScript 的语言处理程序——V8 的垃圾回收。

附录

附录A 简单语言入门: Python篇

附录B简单语言入门: Java篇

附录C简单语言入门: Ruby篇

附录D简单语言入门: JavaScript篇

领取文章中的《垃圾回收的算法与实现》,只需要:

——可以点击此处来获取就可以了!

相关文章
仅操作一台设备,如何实现本地访问另一个相同网段的私网?
仅操作一台设备,如何实现本地访问另一个相同网段的私网?
|
Java 编译器 C语言
深入Java源码剖析之字符串常量
深入Java源码剖析之字符串常量
|
9月前
|
存储 数据采集 数据挖掘
《数据库数据冗余大揭秘:问题与解决方案全解析》
数据冗余是数据库管理中的常见问题,如同家中堆积的杂物,虽看似无害,却会占用存储空间、降低查询效率并增加维护难度。文章分析了数据冗余的成因,如设计不合理、业务需求变化及数据导入导出等,并提出了解决方案,包括数据库规范化设计、数据清洗整合、建立数据字典及优化业务流程。通过实际案例,展示了处理数据冗余对提升数据库性能和业务效率的重要性。重视数据冗余问题,能让数据库更高效地支持业务发展。
637 0
|
安全 网络协议 网络安全
网络不稳定导致HTTP代理频繁掉线的分析
随着数字化时代的加速发展,网络安全、隐私保护及内容访问自由成为用户核心需求。HTTP代理服务器因其独特技术优势受到青睐,但其掉线问题频发。本文分析了HTTP代理服务器不稳定导致掉线的主要原因,包括网络问题、服务器质量、用户配置错误及IP资源问题等方面。
515 0
|
消息中间件 缓存 供应链
“消息驱动、事件驱动、流 ”基础概念解析
本文旨在帮助大家对近期消息领域的高频词“消息驱动(Message-Driven),事件驱动(Event-Driven)和流(Streaming)”有更清晰的了解和认知,其中事件驱动 EDA 作为 Gartner 预测的十大技术趋势之一, EventBridge 作为下一代消息中间件,也是目前的重点方向之一。
552 0
“消息驱动、事件驱动、流 ”基础概念解析
|
编译器
[√]添加预处理的2个不同方式:target_compile_definitions / add_definitions
[√]添加预处理的2个不同方式:target_compile_definitions / add_definitions
836 0
|
编译器 C++
c++ vector的使用
vector 的初始化
213 0
|
缓存 移动开发 运维
mPaaS云平台运维系列之—移动发布产品介绍
实时发布服务(Mobile Delivery Service,MDS)是 mPaaS 平台的核心基础服务组件之一,提供版本升级包、热修复包、H5 离线包的管理和发布服务,同时支持开关配置、白名单、发布规则管理功能。在客户端集成实时发布服务功能后,用户可以在 mPaaS 插件中生成新的包,然后在实时发布控制台发布新包,客户端收到新包并进行升级。实时发布服务还支持通过白名单进行灰度发布,可以使用高级过滤规则,比如指定机型,来进行更精准的灰度发布。
1324 0
mPaaS云平台运维系列之—移动发布产品介绍
|
存储 Java C#
【C语言】strerror函数和malloc函数
我的第一门语言就是C,但是学艺不精,中途跑去学了C#和Java后,感觉到了C的重要性,毕竟是最接近底层的语言,又跑回来学C。 毕竟前两门的控制语句,变量什么的都是类似的,回到C后只需要学习一些特定C的语法,比如宏,预编译指令等等,这些对我来说都是陌生的词汇。 前来记录一下陌生的东西。
365 0