- 问:什么是垃圾收集算法中的分代收集理论?
答:分代收集理论是垃圾收集算法的一种思想,根据对象存活周期的不同将内存分为几块,一般将java堆分为新生代和老年代。这种理论使得我们可以根据各个年代的特点选择合适的垃圾收集算法。
- 问:在新生代中,通常选择哪种垃圾收集算法?
答:在新生代中,每次收集都会有大量对象死去,所以可以选择复制算法。
- 问:标记-清除算法会带来什么问题?
答:标记-清除算法会带来两个明显的问题:1. 效率问题 (如果需要标记的对象太多,效率不高)2. 空间问题(标记清除后会产生大量不连续的碎片)
- 问:垃圾收集器的作用是什么?
答:垃圾收集器是内存回收的具体实现,根据具体应用场景选择适合自己的垃圾收集器。
- 问: Serial收集器是什么?有什么特点?
答:Serial收集器是最基本、历史最悠久的垃圾收集器,是一个单线程收集器。它的特点是简单高效,对于CPU资源有限、内存空间较小、单核CPU环境下的应用场景较为适用。
- 问:复制算法的优点是什么?
答:复制算法的优点在于它只需要付出少量对象的复制成本就可以完成每次垃圾收集,适用于新生代中每次收集都有大量对象死去的情况。
- 问:标记-清除算法的缺点是什么?
答:标记-清除算法会带来两个明显的问题:效率问题和空间问题。如果需要标记的对象太多,效率不高;标记清除后会产生大量不连续的碎片,导致空间浪费。
- 问:标记-整理算法的特点是什么?
答:标记-整理算法是针对老年代的特点特出的一种标记算法。它与“标记-清除”算法的标记过程相同,但后续步骤不是直接对可回收对象回收,而是让所有存活的对象向一端移动,然后直接清理掉端边界以外的内存。
- 问:为什么没有最好的垃圾收集器?
答:因为不同的应用场景对垃圾收集的需求不同,所以没有一种垃圾收集器能够适用于所有场景。此外,不同的垃圾收集器在性能、吞吐量、延迟等方面也有所差异,因此需要根据具体需求选择适合的垃圾收集器。
- 问:什么是垃圾收集器?
答:垃圾收集器是用于自动管理内存的程序,它会自动回收不再使用的对象所占用的内存,以防止内存泄漏。垃圾收集器是内存回收的具体实现。
- 问:Serial收集器有什么特点?
答:Serial收集器是一个单线程收集器,它在进行垃圾收集时会暂停所有的用户线程,直到收集完成。因此,它的暂停时间是可以预测的,但是在大内存、多核处理器环境下,它的性能可能不够理想。
- 问:什么是吞吐量?
答:吞吐量是指程序执行的总时间与程序执行的时间加上垃圾收集的时间之和的比值。高吞吐量意味着垃圾收集的开销较小,程序执行效率较高。
- 问:为什么我们需要选择适合的垃圾收集器?
答:不同的应用场景对垃圾收集的需求不同,例如实时应用需要低延迟的垃圾收集器,而批处理应用则更注重吞吐量。此外,不同的垃圾收集器在性能、吞吐量、延迟等方面也有所差异,因此需要根据具体需求选择适合的垃圾收集器。
- 问:什么是内存泄漏?
答:内存泄漏是指程序在申请内存后,无法释放不再使用的内存空间,导致内存占用不断增加,最终可能导致程序崩溃或性能下降。垃圾收集器的主要作用就是自动回收不再使用的对象的内存,以防止内存泄漏。