当前位置: 首页 > 知识库问答 >
问题:

Java对象JVM的垃圾收集

曾绯辞
2023-03-14

每个java开发人员都知道,java对象不再使用时将被垃圾收集。我想知道JVM如何识别必须为垃圾收集选择的对象。(例如,如果我有10个对象。如果对10个对象中的2个进行垃圾收集,jvm将如何找到这两个对象)。

JVM使用标记和扫描算法(如果我是对的)。

1)例如我在下面提供字符串对象场景

  class Sample{

     public static void main(Strings args[]){
      String s1=new String("10");
      String s2=new String("20");
      String s3=new String("30");
      String s4=new String("40");
      String s5=new String("50");
      String s6=new String("60");
      String s7=new String("70"); 

        s1=null; //now s1 is eligible for gc collection
        s2=null; //now s2 is eligible for collection


 }
}

//现在s1

共有3个答案

邹丰羽
2023-03-14

null分配给任何引用不会释放内存。它只使引用可用于使用垃圾收集器删除。意味着现在当垃圾收集器运行时,此引用分配的内存可以空闲。

苏运良
2023-03-14

这里写得相当简洁:http://www.brpreiss.com/books/opus5/html/page424.html

标记和清除算法被称为跟踪垃圾收集器,因为它跟踪程序直接或间接访问的对象的整个集合。

程序可以直接访问的对象是那些由处理器堆栈上的局部变量以及任何引用对象的静态变量引用的对象。在垃圾回收机制的上下文中,这些变量被称为根。如果一个对象被其他(直接或间接)可访问对象中的字段引用,它就是间接可访问的。

因此,当您执行s1=null;时,您正在断开根连接,相应的实例符合收集条件。

实际的“收集”(释放堆)发生在GC实际执行时。至于确切的时间发生,没有一个万能的答案。请参阅Java中垃圾收集的频率是多少?

魏誉
2023-03-14

实际上什么都没发生。只有当GC开始工作时,s1和s2使用的内存才会被重用,而这只会在JVM决定时发生,而且可能永远不会发生。在您的情况下,GC几乎不会启动。

 类似资料:
  • 有人能给我解释一下原因吗?

  • [GC(分配失败)[defnew:10931K->472K(12288K),0.0053905秒]10931K->10712K(39616K),0.0054285秒][times:user=0.00 sys=0.00,real=0.01秒] [GC(分配失败)[defnew:10712k->472k(12288k),0.0057686秒]20952k->20952k(39616k),0.00580

  • Java堆中存放着大量的Java对象实例,在垃圾收集器回收内存前,第一件事情就是确定哪些对象是“活着的”,哪些是可以回收的。 引用计数算法 引用计数算法是判断对象是否存活的基本算法:给每个对象添加一个引用计数器,没当一个地方引用它的时候,计数器值加1;当引用失效后,计数器值减1。但是这种方法有一个致命的缺陷,当两个对象相互引用时会导致这两个都无法被回收。 根搜索算法 在主流的商用语言中(Java、

  • 主要内容:垃圾回收算法,1、垃圾回收器的分类,2、串行垃圾回收器,3、吞吐量优先,4、响应时间优先,5、G1(Garbage First,jdk9默认),6、Full GC垃圾回收算法 1.标记清除 2.标记复制 3.标记整理 内存效率:复制算法>标记清除算法>标记压缩算法(时间复杂度) 内存整齐度:复制算法=标记清除算法>标记压缩算法 内存利用率:复制算法<标记清除算法=标记压缩算法 年轻代: 存活率低 复制算法 老年代: 区域大,存活率高 标记清除(内存碎片不是太多)+标记压缩共同实现 1、

  • 主要内容:垃圾回收算法,1、垃圾回收器的分类,2、串行垃圾回收器,3、吞吐量优先,4、响应时间优先,5、G1(Garbage First,jdk9默认),6、Full GC垃圾回收算法 1.标记清除 2.标记复制 3.标记整理 内存效率:复制算法>标记清除算法>标记压缩算法(时间复杂度) 内存整齐度:复制算法=标记清除算法>标记压缩算法 内存利用率:复制算法<标记清除算法=标记压缩算法 年轻代: 存活率低 复制算法 老年代: 区域大,存活率高 标记清除(内存碎片不是太多)+标记压缩共同实现 1、

  • 问题内容: 我有两节课 假设我在代码中使用对象B [say ],并在最终使用它后将其设置为。我知道B的对象现在可用于垃圾回收了。 我知道在将b设置为null之后,它将 立即有资格 进行垃圾回收吗?但是类型A的对象呢?将B设置为以后,是否可以 立即 将其用于垃圾回收?还是 在B被垃圾回收之后 才有资格 进行 垃圾回收 ? 从理论上讲,在对B进行垃圾收集之前,还有参考吗?因此,SUN JVM编译器将在