java.util.concurrent.atomic 的包里有AtomicBoolean, AtomicInteger,AtomicLong,AtomicLongArray,
AtomicReference等原子类的类,主要用于在高并发环境下的高效程序处理,来帮助我们简化同步处
理。在Java语言中,++i和i++操作并不是线程安全的,在使用的时候,不可避免的会用到
synchronized关键字。而AtomicInteger则通过一种线程安全的加减操作接口。
(1)创建一个AtomicInteger
private static AtomicInteger firstJobDone = new AtomicInteger(123);
System.out.println(firstJobDone.get());
output: 123
(2)创建一个不传值的AtomicInteger
private static AtomicInteger firstJobDone = new AtomicInteger();
System.out.println(firstJobDone.get());
output:0(默认值为零)
(3)获取以及赋值
firstJobDone.get(); //获取当前值
firstJobDone.set(123); //设置当前值
(4)atomicInteger.compareAndSet(expectedValue,newValue):atomicInteger的值与expectedValue相比较,如果不相等,则返回false, atomicInteger原有值保持不变;如果两者相等,则返回true,atomicInteger的值更新为newValue
public static void main(String[] args) {
AtomicInteger firstJobDone = new AtomicInteger(0);
System.out.println(firstJobDone.get());
int expectedValue = 123;
int newValue = 234;
Boolean b =firstJobDone.compareAndSet(expectedValue, newValue);
System.out.println(b);
System.out.println(firstJobDone);
}
----》输出结果为: 0 false 0
public static void main(String[] args) {
AtomicInteger firstJobDone = new AtomicInteger(123);
System.out.println(firstJobDone.get());
int expectedValue = 123;
int newValue = 234;
Boolean b =firstJobDone.compareAndSet(expectedValue, newValue);
System.out.println(b);
System.out.println(firstJobDone);
}
-----》输出结果为: 123 true 234
(5)getAndAdd()方法 AddAndGet()方法
AtomicInteger firstJobDone = new AtomicInteger(123);
System.out.println(firstJobDone.get()); --123
System.out.println(firstJobDone.getAndAdd(10)); --123 获取当前值,并加10
System.out.println(firstJobDone.get()); --133
System.out.println(firstJobDone.addAndGet(10)); --143 获取加10后的值,先加10
System.out.println(firstJobDone.get()); --143
(6)getAndDecrement()和DecrementAndGet()方法
AtomicInteger firstJobDone = new AtomicInteger(123);
System.out.println(firstJobDone.get()); --123
System.out.println(firstJobDone.getAndDecrement()); --123 获取当前值并自减
System.out.println(firstJobDone.get()); --122
System.out.println(firstJobDone.decrementAndGet()); --121 先自减再获取减1后的值
System.out.println(firstJobDone.get()); --121
AtomicInteger的作用,用原子方式更新的int值。主要用于在高并发环境下的高效程序处理。使用非阻塞算法来实现并发控制。