java 浅析 GC 、堆的分布

1. 堆的分布

  • 1.1 堆的分布图


    image.png
1. java堆被划分成不同的区域:新生代 ( Young )、老年代 ( Old )
2. 新生代 ( Young ) 又被划分为三个区域:Eden、From Survivor、To Survivor。 
3. 新生代占整个堆的1/3、Eden占新生代的1/8、from和to的大小一致各占新生代1/10、老年代占2/3 
4.from区和to去的大小空间是一样的,为什么呢?因为YGC 采用复制算法

2. GC的算法

  • 2.1 标记-清除
    标记-清除算法将垃圾回收分为两个阶段:标记阶段和清除阶段。一种可行的实现是,在标记阶段,首先通过根节点,标记所有从根节点开始的可达对象。因此,未被标记的对象就是未被引用的垃圾对象;然后,在清除阶段,清除所有未被标记的对象。


    image.png
    • 2.1.1 标记-清除算法的缺点:
1.它的缺点就是效率比较低(递归与全堆对象遍历),导致stop the world的时间比较长
2.这种方式清理出来的空闲内存是不连续的
  • 2.2 标记压缩
    标记-压缩算法适合用于存活对象较多的场合,如老年代。它在标记-清除算法的基础上做了一些优化。和标记-清除算法一样,标记-压缩算法也首先需要从根节点开始,对所有可达对象做一次标记;但之后,它并不简单的清理未标记的对象,而是将所有的存活对象压缩到内存的一端;之后,清理边界外所有的空间。


    image.png
    • 2.2.1 标记-压缩算法的缺点:
1.如果在对象存活率较高时就要进行较多的复制操作,效率将会变低。
2.更关键的是,如果不想浪费50%的空间,就需要有额外的空间进行分配担保,以应对被使用的内存中所有对象都100%存活的极端情况,所以在老年代一般不能直接选中这种算法。
  • 2.3 复制算法
    与标记-清除算法相比,复制算法是一种相对高效的回收方法
    不适用于存活对象较多的场合,如老年代(复制算法适合做新生代的GC)
    将原有的内存空间分为两块,每次只使用其中一块,在垃圾回收时,将正在使用的内存中的存活对象复制到未使用的内存块中,之后,清除正在使用的内存块中的所有对象,交换两个内存的角色,完成垃圾回收。


    image.png
    • 2.3.1 复制算法的缺点:
1.复制算法的最大的问题是:空间的浪费

3. GC的触发

image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 1.什么是垃圾回收? 垃圾回收(Garbage Collection)是Java虚拟机(JVM)垃圾回收器提供...
    简欲明心阅读 90,331评论 17 311
  • 从三月份找实习到现在,面了一些公司,挂了不少,但最终还是拿到小米、百度、阿里、京东、新浪、CVTE、乐视家的研发岗...
    时芥蓝阅读 42,725评论 11 349
  • 一. 垃圾回收的意义 在C++中,对象所占的内存在程序结束运行之前一直被占用,在明确释放之前不能分配给其它对...
    Stan_Z阅读 2,046评论 0 25
  • 这篇文章是我之前翻阅了不少的书籍以及从网络上收集的一些资料的整理,因此不免有一些不准确的地方,同时不同JDK版本的...
    高广超阅读 16,024评论 3 83
  • JVM架构 当一个程序启动之前,它的class会被类装载器装入方法区(Permanent区),执行引擎读取方法区的...
    cocohaifang阅读 1,821评论 0 7

友情链接更多精彩内容