GC垃圾收集器只能在安全点才能进行。在java 虚拟机中,安全点(Safepoint)是程序执行过程中,线程可以安全暂停的特定位置。在这些点上,线程的状态(如寄存器、栈等)是已知且一致的,垃圾回收器(GC)可以安全地进行内存回收操作。
安全点的作用
1.垃圾收集
在进行垃圾收集时候,JVM 需要暂停所有应用程序,以确保不会有线程操作内存,同时,状态的快照是确定的,方便GC 工作。
2.堆栈遍历
在执行如线程转储(Thread dump)等操作时,JVM 需要安全的遍历线程栈,这是也是需要安全点。
3.性能消耗最小化
安全点的设置,使得JVM可以减少程序暂停的频率,从而降低性能损耗。
安全点的触发条件
- 主动触发:显式调用
System.gc()或内存不足时触发垃圾回收。 - 被动触发:JVM 在后台定期检查是否需要垃圾回收,如 Eden 区满时触发 Minor GC。
安全点的位置
安全点通常设置在以下位置:
- 方法调用时(包括 JNI 调用)。
- 循环跳转时(避免长时间循环无法进入安全点)。
- 异常抛出时。
示例代码(安全点检查)
以下伪代码展示线程如何检查安全点:
while (true) {
// 业务逻辑
if (global_safepoint_flag) {
stop_for_gc(); // 暂停以等待 GC
}
}
13万+

被折叠的 条评论
为什么被折叠?



