-XX:+ StressLCM,-XX:+ StressGCM JVM的选项

时间:2019-05-23 10:22:27

标签: java jvm jvm-hotspot java-12

在玩一些jcstress代码时,我注意到两个对我来说很新的参数:StressLCMStressGCM

对我来说,第一件事就是在源代码本身中搜索这些内容,尽管我发现了一些内容,但仍不清楚它们实际上是做什么的。我真的很希望在源代码中看到一些注释,这些注释会有所启发,但是没有运气。

我还发现在其中添加了这些内容的bug description,但这种解释对我来说毫无意义:

  

在LCM / GCM中随机化指令调度。

如果可以的话,有人可以用简单的英语解释他们的工作吗?

1 个答案:

答案 0 :(得分:11)

LCM / GCM代表本地代码运动/全局代码运动。为了优化CPU利用率,编译器可以在不更改代码语义的情况下重新排序独立的指令。编译器试图找到最佳的指令(从性能角度来看)。这就是所谓的指令调度,这就是LCM / GCM的作用。

通过-XX:+StressLCM / -XX:+StressGCM选项,指令调度的工作方式略有不同。它不再尝试查找最佳调度,而是在允许的约束范围内选择一个随机指令顺序,而仍保持原始语义不变。这种不确定性行为有助于测试指令交织的更多组合,这对于发现细微的并发问题至关重要。