关于java垃圾回收问题

垃圾回收中,并发处理器,可以有专门的cpu来进行垃圾回收。也就是说用户程序可以与垃圾回收同时运行(或者只有很少时间的停顿)

在标记阶段,查找根对象,标记出所有被引用的对象,类似可用一个map来存取这个对象,以对象为key,value可以是1。

标记完成后,要进行清理。遍历堆,对与 每个对象找之前的标记map,看是否存在,如果不存在则表明该对象应该被回收。

这里就有个问题,因为垃圾回收与用户程序几乎是同时运行(多cpu情况),那边在清理时,用户程序还会产生一部分浮动垃圾。浮动垃圾倒还好办,只要预留一部分内存出来就可以了。那假设有个对象a,原先是应该被回收的,也就是不存于标记map,但是在清理的时候(这部分如果不暂停用户程序)用户程序会产生一个对a的引用。这时如果清除的时候把a清除掉了,那是有问题的。


所以清除的时候用户程序应该暂停,如果不暂停那它是怎么解决这个问题的?

你可能感兴趣的:(关于java垃圾回收问题)