我正在尝试创建一个基准测试(在Groovy中),它显示了几个同步方法的高线程争用。监控自愿上下文切换时应该出现高争用,而在Linux中,这可以通过“pidstat”来实现。
该计划如下:
class Res {
private int n;
synchronized public void inc() {
n++;
def foo = []
for (int i = 0; i < 1000; ++i) foo << "hello"
}
synchronized public int getN() {
return n;
}
}
while (true) {
Res res = new Res()
int N = 100000
for (int i = 0; i < N; ++i) {
new Thread({
res.inc()
if (res.getN() == N) {
println "ok"
}
}).start()
}
while (res.getN() < N) {
}
println "========================="
}
但命令
pidstat -w -I -p 26848 5
在自愿上下文切换列上打印0。该程序创建100000线程,同时访问同步方法。我无法相信,有了这样的工作量,就不会发生上下文切换。
我的基准测试有什么问题?
答案 0 :(得分:6)
您的命令仅显示主线程的统计信息,不计算子PID。
Hotspot JVM有内部同步计数器,但需要一些法术才能解锁它们:
jconsole.exe -J-Djconsole.showUnsupported
并连接到您的JVM。