一、说明:
Stop-the-World,简称STW,指的是GC时间发生过程中,会产生应用程序停顿。停顿产生时整个应用程序线程都会被暂停,没有任何响应,有点像卡死的感觉,这个停顿称为STW。
二、为什么要进行STW:
都知道java采用的是可达性分析算法,可达性分析算法中枚举根节点(GC Roots)会导致java执行线程停顿。
分析工作必须在一个能确保一致性快照中进行。
一致性指整个分析期间整个执行系统看起来像被冻结在某个时间点上。
如果出现分析过程中对象引用关系还在不断变化,则分析结果的准确性无法保证。
三、何时恢复:
被STW中断的应用程序线程会在完成GC之后恢复,频繁中断会让用户感觉像是网速不快造成的电影卡带一样,所以我们需要减少STW的发生。
四、STW事件和采用那款GC无关,所有的GC都有这个事件。
六、哪怕是G1也不能完全避免Stop-the-World 情况发生,只能说垃圾回收器越来越优秀,回收效率越高,尽可能的缩短暂停时间。
七、STW是JVM在后台自动发起和自动完成的。在用户不可见的情况下,把用户正常的工作线程全部停掉。
八、注意:
开发中不要使用System.gc();会导致Stop-the-World的发生。