java synchronized atomic_synchronized与atomic性能对比

写了两个例子,对这两种机制进行对比,发现性能差距在6倍以上。

synchronized的例子:

public class SyncInc {

public static void main(String[] args) {

CountDownLatch latch = new CountDownLatch(10);

long begin = System.nanoTime();

for (int i = 0; i < 10; i++) {

new Thread() {

@Override

public void run() {

while (Number.get() < 100_000_000) {

Number.inc();

}

latch.countDown();

}

}.start();

}

try {

latch.await();

System.out.println("took " + (System.nanoTime() - begin) / 1_000_000 + " ms");

} catch (InterruptedException e) {

e.printStackTrace();

}

}

}

class Number {

public static volatile int value = 0;

public static synchronized void inc() {

value++;

}

public static int get() {

return value;

}

Atomic的例子:

public class AtomicInc {

public static void main(String[] args) {

CountDownLatch latch = new CountDownLatch(10);

long begin = System.nanoTime();

for (int i = 0; i < 10; i++) {

new Thread() {

@Override

public void run() {

while (AtomicNumber.get() < 100_000_000) {

AtomicNumber.inc();

}

latch.countDown();

}

}.start();

}

try {

latch.await();

System.out.println("took " + (System.nanoTime() - begin) / 1_000_000 + " ms");

} catch (InterruptedException e) {

e.printStackTrace();

}

}

}

class AtomicNumber {

public static AtomicInteger value = new AtomicInteger(0);

public static void inc() {

value.incrementAndGet();

}

public static int get() {

return value.get();

}

}

写了两个例子,对这两种机制进行对比,发现性能差距在6倍以上。 synchronized的例子: public class SyncInc { public static void main(String[] args) { CountDownLatch latch = new CountDownLatch(10); long begin = System.nanoTime(); for (int i = 0; i < 10; i++) { new Thread() { @Override public void run() { while (Number.get() < 100_000_000) { Number.inc(); } latch.countDown(); } }.start(); } try { latch.await(); System.out.println("took " + (System.nanoTime() - begin) / 1_000_000 + " ms"); } catch (InterruptedException e) { e.printStackTrace(); } } } class Number { public static volatile int value = 0; public static synchronized void inc() { value++; } public static int get() { return value; } Atomic的例子: public class AtomicInc { public static void main(String[] args) { CountDownLatch latch = new CountDownLatch(10); long begin = System.nanoTime(); for (int i = 0; i < 10; i++) { new Thread() { @Override public void run() { while (AtomicNumber.get() < 100_000_000) { AtomicNumber.inc(); } latch.countDown(); } }.start(); } try { latch.await(); System.out.println("took " + (System.nanoTime() - begin) / 1_000_000 + " ms"); } catch (InterruptedException e) { e.printStackTrace(); } } } class AtomicNumber { public static AtomicInteger value = new AtomicInteger(0); public static void inc() { value.incrementAndGet(); } public static int get() { return value.get(); } }
经验分享 程序员 微信小程序 职场和发展