zoukankan      html  css  js  c++  java
  • AtomicInteger类保证线程安全的用法

    J2SE 5.0提供了一组atomic class来帮助我们简化同步处理。基本工作原理是使用了同步synchronized的方法实现了对一个long, integer, 对象的增、减、赋值(更新)操作. 比如对于++运算符AtomicInteger可以将它持有的integer 能够atomic 地递增。在需要访问两个或两个以上 atomic变量的程序代码(或者是对单一的atomic变量执行两个或两个以上的操作)通常都需要被synchronize以便两者的操作能够被当作是一个atomic的单元。

    java多线程用法-使用AtomicInteger
    下面通过简单的两个例子的对比来看一下 AtomicInteger 的强大的功能
    class Counter {
    private volatile int count = 0;
    
    public synchronized void increment() {
    count++;  //若要线程安全执行执行count++,需要加锁
    }
    
    public int getCount() {
    return count;
    }
    }
    
    class Counter {
    private AtomicInteger count = new AtomicInteger(); 
    
    public void increment() {
    count.incrementAndGet();
    }
           //使用AtomicInteger之后,不需要加锁,也可以实现线程安全。
    public int getCount() {
    return count.get();
    }
    }
    
    从上面的例子中我们可以看出:使用AtomicInteger是非常的安全的
    那么为什么不使用记数器自加呢,例如count++这样的,因为这种计数是线程不安全的,高并发访问时统计会有误,而AtomicInteger为什么能够达到多而不乱,处理高并发应付自如呢?
    这是由硬件提供原子操作指令实现的。在非激烈竞争的情况下,开销更小,速度更快。Java.util.concurrent中实现的原子操作类包括:
    AtomicBoolean、AtomicInteger、AtomicLong、AtomicReference。

      另外其底层就是volatile和CAS 共同作用的结果:

         1.首先使用了volatile 保证了内存可见性。

         2.然后使用了CAS(compare-and-swap)算法 保证了原子性。

           其中CAS算法的原理就是里面包含三个值:内存值A  预估值V  更新值 B  当且仅当 V == A 时,V = B; 否则,不会执行任何操作。

         

  • 相关阅读:
    2019.04.19 坦克大战
    2019.04.18 异常和模块
    2019.04.17 面向对象编程篇207
    fork操作时的copy-on-write策略
    Redis阻塞原因
    Redis持久化-fork操作
    Redis持久化-AOF重写
    Redis持久化-aof
    Redis持久化
    Shopify给左右两边布局的banner图加链接,链接失败
  • 原文地址:https://www.cnblogs.com/baizhanshi/p/5662376.html
Copyright © 2011-2022 走看看