GC介绍
GC介绍
JVM在进行GC时,并不是对这三个区域进行统一回收,大部分时候都是在新生区
- 
新生区 
- 
幸存区:【from和to】 
- 
老年区 GC两种类:轻GC(普通垃圾回收)、重GC(全局垃圾回收)
- 
GC主要存在于方法区和堆中 
- 
面试题目- JVM的内存模型和分区【详细到每个区放什么】
- 堆里面的分区有哪些?新生区【Eden,from,to】、老年区,说说他们的特点
- GC算法有哪些?标记清除法、标记整理/标记压缩、复制算法、引用计数器,怎么用?
- 轻GC和重GC分别在什么时候发生?
 
- 
引用计数器:会有循环引用的问题,不经常使用!
- 
复制算法  可以简单的说GC复制算法就是作用于新生区的 from和to区 - 好处:没有内存碎片
- 坏处:也就是浪费了一个幸存者区也就是to区,复制算法上面也说了就是to区永远都是空的
 最佳使用场景:新生区,毕竟嘛对象存活率较低
 
- 
标记清除压缩算法 
- 
标记清除算法: - 好处:不需要额外的空间
- 坏处:消耗时间多,标记一次、清除一次,有内存碎片
 
- 
标记压缩算法:清除了内存碎片,但是又加长了时间,应该说是用时间换空间 
- 
总结内存效率:复制算法>标记清除法>标记压缩法 内存整齐度:复制算法=标记压缩法>标记清除法 内存利用率:标记压缩法=标记清除法>复制算法 所以说算法没有最优的,只有最合适的_GC:又叫分代收集算法 
年轻代:存活率低,复制算法很合适
老年代:区域大,标记清除(内存碎片不是很多)+标记压缩混合使用
 
                    
                
 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号