AtomicInteger原子操作类

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值。主要用于在高并发环境下的高效程序处理。使用非阻塞算法来实现并发控制。

你可能感兴趣的:(Java基础,java,开发语言,后端)