您当前的位置:首页 > 电脑百科 > 程序开发 > 语言 > JAVA

JAVA并发-AtomicInteger

时间:2020-08-12 09:57:42  来源:  作者:

AtomicInteger 类提供了int类型的变量,变量可以原子写和读,同时还包括先进的原子操作例如 compareAndSet()。 AtomicInteger 类位于JAVA.util.concurrent.atomic 包中,全名java.util.concurrent.atomic. AtomicInteger 。本文讲述JAVA8中的AtomicBoolean ,但是第一个版本是在Java 5中。

关于AtomicInteger 设计原理可以参考 Compare and Swap

创建AtomicInteger

如下代码创建AtomicInteger:

AtomicInteger atomicInteger = new AtomicInteger();

上述例子创建了初始值为0的AtomicInteger ,如果需要创建指定值的AtomicInteger ,则代码如下:

AtomicInteger atomicInteger = new AtomicInteger(123);

例子中用123作为AtomicInteger 构造函数的参数,意思就是AtomicInteger 实例的初始值为123。

获取AtomicInteger 的值

可以通过 AtomicInteger的 get() 方法获取值,下面是代码 AtomicInteger.get():

AtomicInteger atomicInteger = new AtomicInteger(123);
 
int theValue = atomicInteger.get();

设置AtomicInteger的值

可以通过 AtomicInteger 的set()方法设置值,下面是 AtomicInteger.set()的例子

AtomicInteger atomicInteger = new AtomicInteger(123);
 
atomicInteger.set(234);

例子中创建了一个初始值为123的 AtomicInteger,然后设置为234.

比较设置(CAS)的AtomicInteger值

AtomicInteger类同样有原子的compareAndSet()方法,首先与AtomicInteger 实例值得当前比较,如果相对这设置AtomicInteger 的新值,下面AtomicInteger.compareAndSet()代码:

AtomicInteger atomicInteger = new AtomicInteger(123);
 
int expectedValue = 123;
int newValue      = 234;
atomicInteger.compareAndSet(expectedValue, newValue);

首先创建初始值为123的 AtomicInteger实例,然后当前值与期望值123比较,如果相对则设置值为234.

增加AtomicInteger的值

AtomicInteger类包含了一些增加和获取返回值的方法:

  • addAndGet()
  • getAndAdd()
  • getAndIncrement()
  • incrementAndGet()

第一个方法 addAndGet() ,增加AtomicInteger 的值同时返回增加后的值,第二个方法 getAndAdd()增加值,但是返回增加之前的值,两个方法的差别看下面代码:

AtomicInteger atomicInteger = new AtomicInteger();
 
 
System.out.println(atomicInteger.getAndAdd(10));
System.out.println(atomicInteger.addAndGet(10));

代码例子将大于0和20,首先获取AtomicInteger 增加10之前的值是0,然后再增加值并获取当前值是 20.同样可以通过两个方法增加负值,相当于做减法,getAndIncrement()和 incrementAndGet() 与 getAndAdd()和 addAndGet()的工作原理相似,只不是加1.

AtomicInteger 减法

AtomicInteger类同样可以原子性的做减法,面是方法:

  • decrementAndGet()
  • getAndDecrement()

decrementAndGet()方法减1并返回减后的值,getAndDecrement()同样减1并返回减之前的值 。

参考:http://tutorials.jenkov.com/java-util-concurrent/atomicinteger.html

http://tutorials.jenkov.com/java-concurrency/compare-and-swap.html



Tags:JAVA并发   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
Java从版本5开始,在 java.util.concurrent.locks包内给我们提供了除了synchronized关键字以外的几个新的锁功能的实现,ReentrantLock就是其中的一个。但是这并不意味着我们可...【详细内容】
2021-12-17  Tags: JAVA并发  点击:(10)  评论:(0)  加入收藏
本篇文章我们以AtomicInteger为例子,主要讲解下CAS(Compare And Swap)功能是如何在AtomicInteger中使用的,以及提供CAS功能的Unsafe对象。我们先从一个例子开始吧。假设现在我们...【详细内容】
2021-12-14  Tags: JAVA并发  点击:(21)  评论:(0)  加入收藏
Java为我们提供了一些效果非常不错的并发工具类,这里主要介绍一下如下几个工具类的使用,并不会去深究实现原理(其实原理都是通过自旋CAS,CAS对应的处理器原子操作指令是CMPXCHG...【详细内容】
2021-04-27  Tags: JAVA并发  点击:(260)  评论:(0)  加入收藏
AtomicInteger 类提供了int类型的变量,变量可以原子写和读,同时还包括先进的原子操作例如 compareAndSet()。 AtomicInteger 类位于java.util.concurrent.atomic 包中,全名java...【详细内容】
2020-08-12  Tags: JAVA并发  点击:(121)  评论:(0)  加入收藏
java.util.concurrent.ScheduledExecutorService是一个可以安排任务延迟执行的 ExecutorService , 或者以固定的时间间隔重复执行。任务通过一个工作线程异步执行,而不是提交...【详细内容】
2020-08-04  Tags: JAVA并发  点击:(47)  评论:(0)  加入收藏
Disruptor是什么?Disruptor是一个高性能的异步处理框架,一个轻量级的JMS,和JDK中的BlockingQueue有相似处,但是它的处理速度非常快,获得2011年程序框架创新大奖,号称“一个线程一...【详细内容】
2020-07-15  Tags: JAVA并发  点击:(82)  评论:(0)  加入收藏
Java并发工具类主要有CyclicBarrier、CountDownLatch、Semaphore和Exchanger,日常开发中经常使用的是CountDownLatch和Semaphore。下面就简单分析下这几个并发工具类:CyclicB...【详细内容】
2020-06-18  Tags: JAVA并发  点击:(59)  评论:(0)  加入收藏
不考虑多线程并发的情况下,容器类一般使用ArrayList、HashMap等线程不安全的类,效率更高。在并发场景下,常会用到ConcurrentHashMap、ArrayBlockingQueue等线程安全的容器类,虽然牺牲了一些效率,但却得到了安全。...【详细内容】
2020-05-14  Tags: JAVA并发  点击:(43)  评论:(0)  加入收藏
本文主要对Java并发(Concurrent)相关的概念进行说明。1.进程(Process)与线程(Thread) 进程是系统资源分配的最小单元。线程是CPU调度的最小单元。 一个 进程至少包含一个线...【详细内容】
2020-04-29  Tags: JAVA并发  点击:(26)  评论:(0)  加入收藏
Java并发编程之验证volatile指令重排-理论篇Java并发包下的类中大量使用了volatile关键字。通过之前文章介绍,大家已经知道了volatile的三大特性:共享变量可见性;不保证原子性;...【详细内容】
2020-03-23  Tags: JAVA并发  点击:(63)  评论:(0)  加入收藏
▌简易百科推荐
一、Redis使用过程中一些小的注意点1、不要把Redis当成数据库来使用二、Arrays.asList常见失误需求:把数组转成list集合去处理。方法:Arrays.asList 或者 Java8的stream流式处...【详细内容】
2021-12-27  CF07    Tags:Java   点击:(3)  评论:(0)  加入收藏
文章目录 如何理解面向对象编程? JDK 和 JRE 有什么区别? 如何理解Java中封装,继承、多态特性? 如何理解Java中的字节码对象? 你是如何理解Java中的泛型的? 说说泛型应用...【详细内容】
2021-12-24  Java架构师之路    Tags:JAVA   点击:(5)  评论:(0)  加入收藏
大家好!我是老码农,一个喜欢技术、爱分享的同学,从今天开始和大家持续分享JVM调优方面的经验。JVM调优是个大话题,涉及的知识点很庞大 Java内存模型 垃圾回收机制 各种工具使用 ...【详细内容】
2021-12-23  小码匠和老码农    Tags:JVM调优   点击:(11)  评论:(0)  加入收藏
前言JDBC访问Postgresql的jsonb类型字段当然可以使用Postgresql jdbc驱动中提供的PGobject,但是这样在需要兼容多种数据库的系统开发中显得不那么通用,需要特殊处理。本文介绍...【详细内容】
2021-12-23  dingle    Tags:JDBC   点击:(12)  评论:(0)  加入收藏
Java与Lua相互调用案例比较少,因此项目使用需要做详细的性能测试,本内容只做粗略测试。目前已完成初版Lua-Java调用框架开发,后期有时间准备把框架进行抽象,并开源出来,感兴趣的...【详细内容】
2021-12-23  JAVA小白    Tags:Java   点击:(10)  评论:(0)  加入收藏
Java从版本5开始,在 java.util.concurrent.locks包内给我们提供了除了synchronized关键字以外的几个新的锁功能的实现,ReentrantLock就是其中的一个。但是这并不意味着我们可...【详细内容】
2021-12-17  小西学JAVA    Tags:JAVA并发   点击:(10)  评论:(0)  加入收藏
一、概述final是Java关键字中最常见之一,表示“最终的,不可更改”之意,在Java中也正是这个意思。有final修饰的内容,就会变得与众不同,它们会变成终极存在,其内容成为固定的存在。...【详细内容】
2021-12-15  唯一浩哥    Tags:Java基础   点击:(14)  评论:(0)  加入收藏
1、问题描述关于java中的日志管理logback,去年写过关于logback介绍的文章,这次项目中又优化了下,记录下,希望能帮到需要的朋友。2、解决方案这次其实是碰到了一个问题,一般的情况...【详细内容】
2021-12-15  软件老王    Tags:logback   点击:(17)  评论:(0)  加入收藏
本篇文章我们以AtomicInteger为例子,主要讲解下CAS(Compare And Swap)功能是如何在AtomicInteger中使用的,以及提供CAS功能的Unsafe对象。我们先从一个例子开始吧。假设现在我们...【详细内容】
2021-12-14  小西学JAVA    Tags:JAVA   点击:(21)  评论:(0)  加入收藏
一、概述观察者模式,又可以称之为发布-订阅模式,观察者,顾名思义,就是一个监听者,类似监听器的存在,一旦被观察/监听的目标发生的情况,就会被监听者发现,这么想来目标发生情况到观察...【详细内容】
2021-12-13  唯一浩哥    Tags:Java   点击:(16)  评论:(0)  加入收藏
最新更新
栏目热门
栏目头条