共计 355 个字符,预计需要花费 1 分钟才能阅读完成。
应用本地办法 JNI 函数拜访 JVM 中的字符串或数组数据(代码在临界区执行),必须保障原始数据不被批改,避免其它线程的操作、或产生 GC 回收改字符串对象。利用 GC_locker 加锁,保障临界区代码的正确执行。
有线程进入了临界区,导致触发的 YGC 被抛弃。当线程执行完临界区的代码之后,执行 ReleaseStringCritical 办法,来到临界区,这个时候发现触发过 gc,这个时候再触发 gc
会呈现相似日志
(GCLocker Initiated GC) 36377.653: [ParNew: 857904K->15631K(943744K), 0.0208915 secs] 940486K->98215K(4089472K), 0.0210903 secs] [Times: user=0.08 sys=0.00, real=0.02 secs]
正文完