GC介绍
JVM在进行GC时,并不是对这三个区域进行统一回收,大部分时候都是在新生区
-
新生区
-
幸存区:【from和to】
-
老年区
GC两种类:轻GC(普通垃圾回收)、重GC(全局垃圾回收)
-
GC主要存在于方法区和堆中
-
面试题目
- JVM的内存模型和分区【详细到每个区放什么】
- 堆里面的分区有哪些?新生区【Eden,from,to】、老年区,说说他们的特点
- GC算法有哪些?标记清除法、标记整理/标记压缩、复制算法、引用计数器,怎么用?
- 轻GC和重GC分别在什么时候发生?
-
引用计数器:会有循环引用的问题,不经常使用!
-
复制算法
可以简单的说GC复制算法就是作用于新生区的 from和to区
- 好处:没有内存碎片
- 坏处:也就是浪费了一个幸存者区也就是to区,复制算法上面也说了就是to区永远都是空的
最佳使用场景:新生区,毕竟嘛对象存活率较低
-
标记清除压缩算法
-
标记清除算法:
- 好处:不需要额外的空间
- 坏处:消耗时间多,标记一次、清除一次,有内存碎片
-
标记压缩算法:清除了内存碎片,但是又加长了时间,应该说是用时间换空间
-
总结
内存效率:复制算法>标记清除法>标记压缩法
内存整齐度:复制算法=标记压缩法>标记清除法
内存利用率:标记压缩法=标记清除法>复制算法
所以说算法没有最优的,只有最合适的_GC:又叫分代收集算法
年轻代:存活率低,复制算法很合适
老年代:区域大,标记清除(内存碎片不是很多)+标记压缩混合使用
标签:标记,清除,介绍,算法,复制,GC,内存 来源: https://www.cnblogs.com/saxonsong/p/14722266.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。