什么是stop the world
在gc事件发生过程中,会产生应用的停顿,停顿产生时整个应用程序线程都会被暂停,没有任何响应,有点像卡死的感觉,这个停顿称为STW
为什么需要stop the world
可达性分析算法中,枚举根节点(GC ROOT)会导致所有java程序执行线程停顿。
- 分析工作必须在一个能确保一致性的快照中进行
- 一致性指整个分析期间整个执行系统像被冻结在某个时间点上
- 如果出现分析过程中对象引用关系还在不断地变化,则分析结果的准确性无法保证。
举个例子,如果分析时判断该对象已经没有引用,而分析后下一秒该对象又有了引用,则gc时会将该对象清理,导致错误发生。