一、前言:
上一遍博客中已经提及了volatile关键字虽然拥有了多个线程之间的可见性,但是却不具备同步性(也就是原子性),可以算的上是线程同步的轻量级实现,性能要比synchronized强很多,不会造成阻塞(在很多开源的框架里,比如netty的底层代码就大量使用volatile,可见netty性能一定是非常不错的)。
二、实现原子性:
volatile关键字只具有可见性,没有原子性,要实现原子性建议使用atomic类的系列对象,支持原子性操作(注意atomic类只保证半身方法的原子性,并不保证多次操作的原子性)
public class VolatileNoAtomic extends Thread{
private static volatile int count;
//private static AtomicInteger count = new AtomicInteger(0);
/*synchronized*/
private static void addCount(){
for (int i = 0; i < 1000; i++) {
count++ ;
//count.incrementAndGet();
}
System.out.println(count);
}
public void run(){
addCount();
}
/*10个线程对一个count变量进行+