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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值