JVM之复制算法

一、背景:

二、核心思想:

三、图解:

不用标记存活对象,直接将A中存活的对象复制到B中。

四、优缺点:

优点:

a.没有标记和清除过程,实现简单,运行高效。

b.复制过去以后保证空间的连续性,不会出现“碎片” 问题。(使用的指针碰撞分配内存)

缺点:

a.此算法的缺点也是很明显的,就是需要两倍的内存空间。

b.对于G1这拆分成为大量region 的GC,复制而不是移动,就意味着GC需要维护region之间对象引用关系,不管是内存占用或者时间开销也不小。

java 对象访问使用的是直接访问,而不是句柄池访问:

 五、注意:

如果系统中的垃圾对象很多,复制算法不会很理想。因为复制算法需要复制的存活对象数量并不会太大,或者说非常低才行。

六、应用场景:

 新生代大部分对象都是朝生夕死的。

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值