こんにちはみんな、私はこのコードを手に入れました
public class Padding {
static class Pair {
volatile long c1;
// UN-comment this line and see how perofmance is boosted * 2
// long q1; //Magic dodo thingy
volatile long c2;
}
static Pair p = new Pair();
static class Worker implements Runnable {
private static final int INT = Integer.MAX_VALUE/8;
private boolean b;
Worker(boolean b) {
this.b = b;
}
public void run() {
long start = System.currentTimeMillis();
if (b) {
for (int i = 0; i < INT; i++) {
p.c1++;
res += Math.random();
}
} else {
for (int i = 0; i < INT; i++) {
p.c2++;
res += Math.random();
}
}
long end = System.currentTimeMillis();
System.out.println("took: " + (end-start) + " Result:" + p.c1+p.c2);
}
}
public static void main(String[] args) {
System.out.println("Starting....");
Thread t1 = new Thread(new Worker(true));
Thread t2 = new Thread(new Worker(false));
t1.start();
t2.start();
}
}
したがって、実行すると約11秒かかりますが、qa1のコメントを外すと3秒で実行されます。インターネットで何かを見つけようとしましたが、十分な情報が得られませんでした。私が理解しているように、それはJVMの最適化と関係があり、長いq1はおそらくメモリ(またはキャッシュ)の分散をいくらか改善します。私の質問はいずれにせよ、誰かがそれについてもっと読むことができる場所を知っていますか. ありがとう