应用本地办法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]