垃圾回收-如何判断是一个垃圾

判断垃圾-引用计数法

判断一个对象是否存活:给这个对象增加一个引用计数器,当有一个地方引用他时就加1,当引用失效就减1,计数器为0的对象就是可以回收的。

缺陷:很难解决对象之间循环引用的问题。如:objA.instance=objB,objB.instance=objA,除此之外这两个对象没有任何引用,但是因为他们彼此引用,导致无法回收。

判断垃圾-可达性分析算法

   找到一些gc Roots对象,然后从这些对象进行向下搜索,搜索走过的路程称为引用链,当一个对象到gc roots没有任何引用链时,证明此对象是一个垃圾。

 

判断垃圾-引用计数法

判断一个对象是否存活:给这个对象增加一个引用计数器,当有一个地方引用他时就加1,当引用失效就减1,计数器为0的对象就是可以回收的。

缺陷:很难解决对象之间循环引用的问题。如:objA.instance=objB,objB.instance=objA,除此之外这两个对象没有任何引用,但是因为他们彼此引用,导致无法回收。

判断垃圾-可达性分析算法

   找到一些gc Roots对象,然后从这些对象进行向下搜索,搜索走过的路程称为引用链,当一个对象到gc roots没有任何引用链时,证明此对象是一个垃圾。

引用分类

     如果reference类型的数据中存储的数值代表的是另一块内存的起始地址,就称这款内存代表着一个引用。一个对象在这种定义下只有被引用和没有被引用两种状态。如果需要描述这样一类对象,当内存空间足够时,能保留在内存中,如果内存非常紧张,则可以抛弃这些对象。

以此为背景,java对引用的概念进行了扩充,分为强引用,软引用,弱引用,虚引用,强度依次逐渐减弱。

强引用:类似object obj=new Obeject();这类引用,只要强引用存在,垃圾收集器就永远不会回收掉的对象。

软引用:用来描述一些还有用但并非必需的对象。软引用的对象是在系统将要发生内存溢出之前,会把这些对象列进回收范围之中进行第二次回收。

弱引用:比软引用更弱,被弱引用关联的对象只能生存到下一次垃圾回收之前。

虚引用:是最弱的一种引用。虚引用不会对一个对象的存活时间有任何的影响,设置虚引用的目的就是在这个对象被收集器回收的时候收到一个系统通知。

引用分类

     如果reference类型的数据中存储的数值代表的是另一块内存的起始地址,就称这款内存代表着一个引用。一个对象在这种定义下只有被引用和没有被引用两种状态。如果需要描述这样一类对象,当内存空间足够时,能保留在内存中,如果内存非常紧张,则可以抛弃这些对象。

以此为背景,java对引用的概念进行了扩充,分为强引用,软引用,弱引用,虚引用,强度依次逐渐减弱。

强引用:类似object obj=new Obeject();这类引用,只要强引用存在,垃圾收集器就永远不会回收掉的对象。

软引用:用来描述一些还有用但并非必需的对象。软引用的对象是在系统将要发生内存溢出之前,会把这些对象列进回收范围之中进行第二次回收。

弱引用:比软引用更弱,被弱引用关联的对象只能生存到下一次垃圾回收之前。

虚引用:是最弱的一种引用。虚引用不会对一个对象的存活时间有任何的影响,设置虚引用的目的就是在这个对象被收集器回收的时候收到一个系统通知。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章