编程语言
首页 > 编程语言> > Java-垃圾回收

Java-垃圾回收

作者:互联网

1.1对象优先在eden区分配

大多数情况下,对象在新生代中eden区分配,当eden没有足够多空间分配的时候,虚拟机将发起一次MinorGC

 

针对HotSpotVM的实现,里面的GC主要分为两大种:

部分收集(PartialGC)

  1、新生代收集(MinorGC/Younggc):只对新生代进行垃圾收集

  2、老年代收集(MajorGC/OldGC):只对老年代进行垃圾回收,需要注意的是MajorGC在有语境中也用于指代整堆收集

  3、混合收集(MixedGC):对整个新生代和部分老年代进行垃圾收集

整堆收集(Full GC):对整个JAVA堆和方法区收集。

 

 

判断对象死亡:

1.1引用计数法:(目前基本不用了)

如果对象有引用就不是死亡,但是会出现循环引用的现象。回收不了

1.2可达性分析算法

基本思想:通过一系列的GCRoots的对象作为起点,从这些节点开始向下搜索,节点锁走过的路径称为引用链,当一个对象到GC Roots每页任何引用链引用的话,则需要回收

那些对象可以作为GC Roots呢?

1、虚拟机栈(栈帧的本地变量表)中的引用对象。

2、本地方法栈(Native 方法)中引用的对象

3、方法区中类静态属性引用的对象

4、方法区中常量引用的对象

5、所有被同步锁持有的对象

 

三、对象可以被回收,就一定可以被回收吗?

即使在可达性分析法中不可达的对象,也并非是非死不可的,因为可能处于缓刑状态,真正宣告一个对象死亡,

至少要经历两次标记过程;可达性分析法中不可达的对象被第一次标记并且进行筛选,筛选的条件是次对象是是否有必要

执行finalize的方法。当对象没有覆盖finalize方法,或者finalize方法已经被虚拟机调用过的时候,虚拟机将这两种情况视为没有必要执行。

 

被判定为需要执行的对象将会被放在一个队列中进行第二次标记,除非这个对象与引用链上的任何一个对象建立了联系,否则就会真的被回收。

finalize方法弊端(每个类都有finalizer,它不能被直接调用,而被jvm在适当的时候调用,作为一种收尾机制):

1、行为不稳定

2、降低性能

3、可移植性低

(使用finalizer最严重的缺点是不能保证被执行,一个对象变得不可达开始,一直到该对象被jvm终结,过程中时间是未知的。当一个类提供了finalizer,会查看finalizer队列是否很多实例等待被终结。

     

 

标签:Java,收集,对象,虚拟机,回收,finalizer,垃圾,引用
来源: https://www.cnblogs.com/Alei777/p/16228274.html