JAVA 中无锁的线程安全整数 AtomicInteger介绍和使用

Posted 大树叶

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JAVA 中无锁的线程安全整数 AtomicInteger介绍和使用相关的知识,希望对你有一定的参考价值。

JAVA 中无锁的线程安全整数 AtomicInteger,一个提供原子操作的Integer的类。在Java语言中,++i和i++操作并不是线程安全的,在使用的时候,

不可避免的会用到synchronized关键字。而AtomicInteger则通过一种线程安全的加减操作接口。AtomicInteger为什么能够达到多而不乱,处理高并发应付自如呢?

这是由硬件提供原子操作指令实现的,这里面用到了一种并发技术:CAS。在非激烈竞争的情况下,开销更小,速度更快。 Java.util.concurrent中实现的原子操作类包括: AtomicBoolean、AtomicInteger、 AtomicIntegerArray、AtomicLong、AtomicReference、 AtomicReferenceArray

/**
 * 来看AtomicInteger提供的接口。

 //获取当前的值
 
 public final int get()
 
 //取当前的值,并设置新的值
 
  public final int getAndSet(int newValue)
 
 //获取当前的值,并自增
 
  public final int getAndIncrement()
 
 //获取当前的值,并自减
 
 public final int getAndDecrement()
 
 //获取当前的值,并加上预期的值
 
 public final int getAndAdd(int delta) 


例子代码为:

AtomicOperationDemo.java

import java.util.*;
import java.util.concurrent.*;
import java.util.concurrent.atomic.*;
/*
 * ava.util.concurrent中实现的原子操作类包括:
AtomicBoolean、AtomicInteger、AtomicIntegerArray、AtomicLong、AtomicReference、
AtomicReferenceArray。
 * 
 */
public class AtomicOperationDemo 
	   static AtomicInteger count=new AtomicInteger(0);
	   public static class AddThread implements Runnable
		@Override
		public void run() 
			for(int k=0;k<1000;k++)
				count.incrementAndGet();
			
		  
	   
	   public static void AtomicIntShow()
		 System.out.println("AtomicIntShow() enter");
		 ExecutorService threadpool =   Executors.newFixedThreadPool(10);
		 
		 for(int k=0;k<100;k++)
			 threadpool.submit(new AddThread());
		 
		 
		 try 
			Thread.sleep(2000);
		 catch (InterruptedException e) 
			// TODO Auto-generated catch block
			e.printStackTrace();
		
		 
		 /* output
		  * AtomicIntShow() enter
		  * result of acumulated sum=100000
		  * AtomicIntShow() exit
		  */
		 
		 System.out.println("result of acumulated sum="+count);
		 threadpool.shutdown();
		 System.out.println("AtomicIntShow() exit");
		 return ;
		
	



Maintest.java

public class Maintest 
	public static void main(String[] args) 
		AtomicOperationDemo.AtomicIntShow();
	


  1. /* output 
  2.           * AtomicIntShow() enter 
  3.           * result of acumulated sum=100000 
  4.           * AtomicIntShow() exit 
  5.           */  

以上是关于JAVA 中无锁的线程安全整数 AtomicInteger介绍和使用的主要内容,如果未能解决你的问题,请参考以下文章

C ++ 11中无锁的多生产者/消费者队列

Java 多线程分析----CAS操作和阻塞

Java 并发编程线程锁机制 ( 锁的四种状态 | 无锁状态 | 偏向锁 | 轻量级锁 | 重量级锁 | 锁竞争 | 锁升级 )

CAS无锁策略

java核心-多线程- 并发原子类

java-CAS无锁算法