新生区
幸存区:【from和to】
老年区
GC主要存在于方法区和堆中
- JVM的内存模型和分区【详细到每个区放什么】
- 堆里面的分区有哪些?新生区【Eden,from,to】、老年区,说说他们的特点
- GC算法有哪些?标记清除法、标记整理/标记压缩、复制算法、引用计数器,怎么用?
- 轻GC和重GC分别在什么时候发生?
可以简单的说GC复制算法就是作用于新生区的 from和to区
标记清除算法:
标记压缩算法:清除了内存碎片,但是又加长了时间,应该说是用时间换空间
内存效率:复制算法>标记清除法>标记压缩法
内存整齐度:复制算法=标记压缩法>标记清除法
内存利用率:标记压缩法=标记清除法>复制算法
所以说算法没有最优的,只有最合适的_GC:又叫分代收集算法
年轻代:存活率低,复制算法很合适
老年代:区域大,标记清除(内存碎片不是很多)+标记压缩混合使用