java虚拟机如何判断两个类相同,深入理解Java虚拟机(2)

1、GC过程

09cd1db4a7bc862655eec5380be76f41.png

2、对象已死判断算法

a8294f1bb59560590e3478dc137bdaa1.png

3、对象的引用:

d761fefcd22e1601724680509d4aa0ed.png

4、垃圾收集算法

7ddcff1a8618f505db481cbc228212bb.png

补充堆中区域划分

5fcd2dea936da72bbeba9afc050c8763.png

5、垃圾收集器

7a4dc67ae30b30f810b807aede8db052.png

Parallel Scavenge:吞吐量优先收集器,与ParNew区别在于多了自适应调节策略

CMS:以获取最短回收停顿时间为目标的收集器,是基于标记-清除算法实现的收集器。

补充两个概念:

并行(Parallel):指多个垃圾收集线程工作、但此时用户线程仍然处于等待状态。

并发(ConCurrent):指用户线程与垃圾收集线程同时执行。

6、内存分配过程

一般过程:

1、TLAB((Thread Local Allocation Buffer))

2、优先堆新生代eden区

3、大对象进入堆老年代

4、新生代GC(Minor GC)发生,存活对象则优先新生代Survivor区,若存活对象大于Survivor区,则通过担保机制进入老年代。

1)默认新生代Eden、Survivor比例是多少?

-8:1,整个新生代包括Eden区和2个Survivor区,也就是如果新生代共10M,则Eden分配8M,2个Survivor各为1M。

-XX:SurvivorRatio=8设置比例值。

2)新生代GC和老年代GC的有啥不一样?

-新生代GC发生频繁,速度快。

-新生代GC采用复制算法,老年代GC采用标记整理算法。

3)新生代Survivor区的对象如何进入老年代?

-Survivor存活年龄(新生代GC一次,年龄+1)大于MaxTenuringThreshold值。

-相同年龄的对象之和大于Survivor大小的一半。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值