码迷,mamicode.com
首页 > 其他好文 > 详细

高并发编程-07-JDK提供的原子类操作及原理

时间:2018-01-13 11:11:10      阅读:140      评论:0      收藏:0      [点我收藏+]

标签:sof   cin   swa   mic   ping   并发   bottom   通过   text   

1,原子类介绍:

针对数据类型的操作,JDK提供的原子类来方便我们的线程安全控制。

所有的类保存在 java.util.concurrent.atomic 包中

基本数据类型 AtomicInteger

数组类型 AtomicIntegerArray

2,举个使用的例子:

解决之前的 i++ 安全性问题

如何解决?

AtomicInteger count = new AtomicInteger(0);

count.incrementAndGet();//相当于count++,区别是这里可以保证是原子操作

3,原理:

内部的原理是采用了CAS机制,大家可以通过观察源码就可以发现

那么什么是CAS机制?

CAS有人翻译为Compare And Set或Compare And Swap都是正确的。

在多线程并发执行的状态下,锁的状态改变,基本都是使用CAS原理,它有一个比较别扭的叫法“CPU硬件同步原语”,算法是基于CPU硬件的,原子性操作,不会被其他线程打断。

CAS的算法,比较当前值和期望的值是否相等,如果相等,则将当前值赋予一个新值。

再比如修改一个Boolean的类型的变量的值,我们也可以采用

private AtomicBoolean atomicBoolean = new AtomicBoolean(false);

public void lock(){

    //期望是false,如果是false,则可以修改为true

    atomicBoolean.compareAndSet(false, true);

}



高并发编程-07-JDK提供的原子类操作及原理

标签:sof   cin   swa   mic   ping   并发   bottom   通过   text   

原文地址:http://blog.51cto.com/huangguizhao/2060480

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!