java垃圾回收机制

一、JVM内存模型
在java虚拟机运行程序时,会把管理的内存分为以下几个区域:
1.方法区:主要用于存储虚拟机加载的类信息、常量、静态变量。
2.堆:jvm管理的内存中最大的一块,主要存放对象实例。
3.程序计数器:代表当前线程所执行的字节码行号指示器。字节码解释器工作时,通过改变这个计数器的值来选取下一条需要执行的字节码指令,分支、循环、跳转、异常处理、线程恢复等基础功能都需要依赖这个计数器来完成。
4.虚拟机栈:每个方法被执行的时候都会同时创建一个栈帧,用来存储。局部 变量表,操作栈,动态链接,方法出口等信息。每个方法从调用直到执行完成的过程,都对应一个栈帧在虚 拟机栈中从入栈到出栈的过程。
5.本地方法栈:与虚拟机栈发挥的功能非常类似,执行native方法而服务。

二、GC如何发现垃圾?
1.引用计数法
在这里插入图片描述
此种算法会在每一个对象上记录这个对象被引用的次数,只要有任何一个对象引用了次对象,这个对象的计数器就+1,取消对这个对象的引用时,计数器就-1。任何一个时刻,如果该对象的计数器为0,那么这个对象就是可以回收的。
2.根搜索算法
在这里插入图片描述
设立若干种根对象,当任何一个根对象到某一个对象均不可达时,则认为这个对象是可以被回收的。
三、GC回收垃圾算法
1.标记清除算法在这里插入图片描述标记出所有需要回收的对象,在标记完成后统一回收掉所有被标记的对象。缺点:会产生内存碎片,当需要较大内存空间保存对象时,会因为找不到足够的内存空间而触发另一次垃圾回收动作。
2.分段复制算法在这里插入图片描述
这种算法将内存空间分为大小相等的两块,每次只使用一块,当一块用完后将存活的对象转移到另一块,再把已使用过的内存空间一次清理掉。这样使得每次都是对其中的一块进行内存回收,内存分配时也就不用考虑内存碎片等复杂情况。实现简单,运行高效。缺点:是将内存缩小为原来的一半,需要更大的内存空间。
3.标记整理算法在这里插入图片描述
标记过程与标记清除算法一样,但后续步骤不是直接对可回收对象进行清理,而是让所有存活的对象都向一端移动,然后直接清理掉端边界以外的内存。
4.分代收集算法
在这里插入图片描述按照对象对象存活周期的不同, 将内存划分为几块。一般是把堆分为新生代和年老带,根据各个年代采用最合适的算法。譬如在新生代每次垃圾回收只有少量的存活,就使用分段复制法,在年老代中,对象都活的久,没有额外的内存担保空间,就采用标记整理。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值