GCLocker介绍

使用本地方法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]

你可能感兴趣的:(java)