共计 1092 个字符,预计需要花费 3 分钟才能阅读完成。
《垃圾回收的算法与实现》第 1 章学习 GC 之前
垃圾回收系列连载:
第 1 章 学习 GC 之前
第 2 章 GC 标记 - 革除算法
第 3 章 援用计数法
第 4 章 GC 复制算法
第 5 章 GC 标记 - 压缩算法
第 6 章 激进式 GC
第 7 章 分代垃圾回收
第 8 章 增量式垃圾回收
第 9 章 RC Immix 算法
第 10 章 Python 的垃圾回收
第 11 章 DalvikVM 的垃圾回收
第 12 章 Rubinius 的垃圾回收
电子书下载链接
第 1 章 学习 GC 之前
初识 GC
- GC 的定义
GC,垃圾回收 就是把不要的货色丢掉。在程序外面了解就是找到不再应用的内存空间,而后回收,前面能够再此应用回收掉的内存。
- 为什么须要 GC
C++ 外面是程序员本人治理内存,操作指针,然而操作指针特地危险,会呈现野指针,空指针。还有程序员要明确什么时候开释须要本人治理。Java 就思考到 C ++ 程序员的苦处,就想到让语言自身去解决内存治理的问题,你们下层不必管,我来兜底。算是一种语言缺点的补充。
- GC 的倒退
每项技术都会有它的倒退,都会有几种策略的竞争,GC 一开始是 标记 - 革除法,前面来了援用技术法,而后来了 GC 复制算法,都是在解决前人的缺点,当然也会带来新问题,都有本人的短处和短处。
前置知识点
对于 C ++ 和 java 根底的知识点这里不做赘述。
- 对象头
对象头会蕴含 对象的大小 对象的品种的信息
- 对象域
域中的数据类型分为两种 指针和非指针。这里就是 java 的数据类型要么是惯例数据类型 要么是对象援用的意思。
- mutato
就是程序的意思。
- 堆
就是援用对象的指针指向的存储地位。java 外面的对象的实体都存在堆中。
- 根
根就是指向对象的指针的终点,调用栈、寄存器、全局变量都是根。这些根都是流动对象。
- 吞吐量
下图所示,HeapSize/(A+B+C) 就是吞吐量,治理越多的内存吞吐量越大,GC 耗时越小吞吐量越大。
- 最大暂停工夫
这个是针对标记革除来说,因为标记和革除是要暂停的,不暂停会扭转援用对象,那么标记的非流动对象就可能脏了。
- 堆应用效率
这个是针对复制算法的,因为有一半的堆空间应用不到,那么堆应用效率就很低了。
- 拜访局限性
这里就是拜访的效率,跟语言无关,就是对象的援用关系阐明他们是有可能会被间断拜访,那么应该在内存中间断,这样访问速度会更快,那么有的 GC 算法会思考到把有关联的援用对象放在一起,比方复制算法,计算援用就在拷贝,那么就会放在一起。
请期待“第 2 章 GC 标记 - 革除算法”
个人简介:高级开发工程师,趣味和畛域(Unity、Unreal、cocos creator、安卓终端开发、ios 终端开发、音视频开发、图形学),欢送加 W:wlxklyh 探讨问题。(欢送 star:https://github.com/wlxklyh/So…)