Java控制并发 AtomicBoolean Lock Volatile

一、作为开关

a.   AtomicBoolean

	private AtomicBoolean update = new AtomicBoolean(false);
	public void init()
	{
	   if( this.update.compareAndSet(false, true) )
	   {
		   try{
			// do some thing
		   }
		   finally{
			this.refresh.set(false);
		   }
	   }
	}
b.   volatile

	public volatile boolean update = false;
	public void init()
	{
	    if( update == false ){
	        update = true;
	        // dp some thing
	    }
	}

二,计数器

a.AtomicInteger 

	private static  AtomicInteger a = new AtomicInteger(0);
	a.getAndIncrement();


b.sychrognized + volatile

扫描二维码关注公众号,回复: 8746064 查看本文章
	private volatile int value;
	public int getValue() { return value; }

    public synchronized int increment() {
        return value++;
    }

疑问:这里把volatile 关键字去掉会有什么不一样吗???

回答:不可以,去掉的时候,多线程的时候,其他的线程会读到缓存在寄存器的值


三、用Lock

	private Lock lock = new ReentrantLock();
	public void m1(){
		this.lock.lock(); 
		try{
			//do some thing
		}finally{
			lock.unlock();
		}
	}





发布了327 篇原创文章 · 获赞 82 · 访问量 89万+

猜你喜欢

转载自blog.csdn.net/kkgbn/article/details/37903577
今日推荐