CLR 的 GC是基于代的垃圾回收器,总共三代。 第0 代,第一代 第二代。我觉得JAVA 的JVM 也查不是很多。
CLR 开始GC时,会暂停进程中的所有线程,这是为什么呢?
主要是防止线程在CLR检查期间访问了某个对象改变了这个对象的状态。
聪明的你肯定也知道了垃圾回收最开始的阶段 会进行当前 托管堆中所有对象进行遍历,进行标记,有引用的 标记为 1 没有引用的标记为 0,标记为0 的则是GC需要回收的。
java也有弱引用吗?
现阶段jvm的stw主要发生在对象标记阶段,即使是号称低延迟的cms和g1收集器在初始阶段对可回收对象进行可达性分析的时候也需要短暂的stw,原因就是其他线程在执行的时候可能会改变对象的引用状态,比如在进行标记的时候已经被标记为可回收的对象可能被再次引用,就会造成回收了不能被回收的对象而出现问题