Java中内存分配和回收策略、新生代、老年代

       Java中对于垃圾回收的策略有多种,而目前商业虚拟机的垃圾收集都采用“分代收集”,这种算法是根据对象存活周期的不同将内存分为几块,一般是将Java堆分为新生代和老年代,根据各个年代的特点采用较适合的收集算法。

       新生代中采用的收集算法:复制算法。算法的思想是将可用内存分为大小相等的两块,每次使用其中一块,当一块内存用完了,就将还存活的对象分到另一块。然后把使用过的内存空间一次进行清理。这种算法缺点会明显,就是会浪费一半的空间。而根据IBM研究表明,新生代中98%的对象朝生夕死,所以不需要按照1:1进行分配,而是按照内存分为一块较大的Eden空间和两块较小的Survivor空间(from和to两个),每次使用Eden和其中一个Survivor。当回收时,将Eden和其中一块Survivor中还存活着的对象一次性复制到另一块Survivor中,然后清理Eden和刚才用过的Survivor空间。一般默认的比例为:Eden:from:to=8:1:1。注:可通过-XX:SurvivorRatio=i来设置,默认i=8。当Survivor空间不够时,需要依赖其他内存(老年代)进行分配担保。内存的分配担保:如果另一块Survivor空间没有足够的内存空间存放上一次新生代收集下来的存活对象,那么这些对象将直接通过分配担保机制进入老年代

       老年代中采用的收集算法:

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值