java线程:Atomic(原子的)

转载 2015年11月20日 11:03:49
一、何谓Atomic?
 Atomic一词跟原子有点关系,后者曾被人认为是最小物质的单位。计算机中的Atomic是指不能分割成若干部分的意思。
如果一段代码被认为是Atomic,则表示这段代码在执行过程中,是不能被中断的。通常来说,原子指令由硬件提供,供
软件来实现原子方法(某个线程进入该方法后,就不会被中断,直到其执行完成)
 在x86 平台上,CPU提供了在指令执行期间对总线加锁的手段。CPU芯片上有一条引线#HLOCK pin,如果汇编语言的程序
中在一条指令前面加上前缀"LOCK",经过汇编以后的机器代码就使CPU在执行这条指令的时候把#HLOCK pin的电位拉低,
持续到这条指令结束时放开,从而把总线锁住,这样同一总线上别的CPU就暂时不能通过总线访问内存了,保证了这条指
令在多处理器环境中的原子性。
二、JDK1.5的原子包:java.util.concurrent.atomic
这个包里面提供了一组原子类。其基本的特性就是在多线程环境下,当有多个线程同时执行这些类的实例包含的方法时
,具有排他性,即当某个线程进入方法,执行其中的指令时,不会被其他线程打断,而别的线程就像自旋锁一样,一直
等到该方法执行完成,才由JVM从等待队列中选择一个另一个线程进入,这只是一种逻辑上的理解。实际上是借助硬件的
相关指令来实现的,不会阻塞线程(或者说只是在硬件级别上阻塞了)。其中的类可以分成4组
AtomicBoolean,AtomicInteger,AtomicLong,AtomicReference
AtomicIntegerArray,AtomicLongArray
AtomicLongFieldUpdater,AtomicIntegerFieldUpdater,AtomicReferenceFieldUpdater
AtomicMarkableReference,AtomicStampedReference,AtomicReferenceArray
Atomic类的作用
使得让对单一数据的操作,实现了原子化
使用Atomic类构建复杂的,无需阻塞的代码
访问对2个或2个以上的atomic变量(或者对单个atomic变量进行2次或2次以上的操作)通常认为是需要同步的,以达到
让这些操作能被作为一个原子单元。
2.1 AtomicBoolean , AtomicInteger, AtomicLong, AtomicReference
这四种基本类型用来处理布尔,整数,长整数,对象四种数据。
构造函数(两个构造函数)
默认的构造函数:初始化的数据分别是false,0,0,null
带参构造函数:参数为初始化的数据
set( )和get( )方法:可以原子地设定和获取atomic的数据。类似于volatile,保证数据会在主存中设置或读取
getAndSet( )方法
原子的将变量设定为新数据,同时返回先前的旧数据
其本质是get( )操作,然后做set( )操作。尽管这2个操作都是atomic,但是他们合并在一起的时候,就不是atomic。在
Java的源程序的级别上,如果不依赖synchronized的机制来完成这个工作,是不可能的。只有依靠native方法才可以。
compareAndSet( ) 和weakCompareAndSet( )方法
这两个方法都是conditional modifier方法。这2个方法接受2个参数,一个是期望数据(expected),一个是新数据(new)
;如果atomic里面的数据和期望数据一致,则将新数据设定给atomic的数据,返回true,表明成功;否则就不设定,并返回false。
对于AtomicInteger、AtomicLong还提供了一些特别的方法。getAndIncrement( )、incrementAndGet( )、
getAndDecrement( )、decrementAndGet ( )、addAndGet( )、getAndAdd( )以实现一些加法,减法原子操作。(注意 

--i、++i不是原子操作,其中包含有3个操作步骤:第一步,读取i;第二步,加1或减1;第三步:写回内存)

private final java.util.concurrent.atomic.AtomicBoolean status = new AtomicBoolean(false);

Java多线程/并发16、Atomic原子变量和原子操作

在Java中,i++这类的操作看起来只有一行,其实java 分成了三步去做 1、获取i值 2、计算i+1; 3、将结果存入i; 因此i++不是原子操作,非线程安全的,多线程访问的时候需要用到s...
  • soonfly
  • soonfly
  • 2017年04月28日 17:11
  • 1237

java线程——Atomic(原子的)

转自http://thomaschen2011.iteye.com/blog/1468085 一、何谓Atomic? 计算机中的Atomic是指不能分割成若干部分的意思。如果一段代码被认为是At...
  • chuntiandejiaobu10
  • chuntiandejiaobu10
  • 2016年08月17日 10:15
  • 87

java线程:Atomic(原子的)

一、何谓Atomic?  Atomic一词跟原子有点关系,后者曾被人认为是最小物质的单位。计算机中的Atomic是指不能分割成若干部分的意思。如果一段代码被认为是Atomic,则表示这段代码在执...
  • telenewbie
  • telenewbie
  • 2015年04月16日 11:10
  • 509

原子访问(Atomic Access)

在编程中,原子操作是指在一次发生中生效。一个原子操作不能在中途停止:它要么完整发生,要么不发生。没有副作用的原子操作是可见的,直到完成。   我们见过自增表达式了,如c++,并不是原子操作,甚至非常简...
  • rjcs888
  • rjcs888
  • 2016年07月05日 23:38
  • 495

原子(atomic)跟非原子(non-atomic)属性有什么区别

1). atomic提供多线程安全。是防止在写未完成的时候被另外一个线程读取,造成数据错误 2). non-atomic:在自己管理内存的环境中,解析的访问器保留并自动释放返回的值,如果指定了 ...
  • bowei1105
  • bowei1105
  • 2017年04月05日 08:10
  • 271

C++多线程-第一篇-Atomic-原子操作

此系列基于Boost库多线程,但是大部分都在C++11中已经实现,所以两者基本一致。没什么特殊要求,练手还是C++11吧,方便不用配置。 PS:Boost不愧为C++准标准库。 本来不打算写,毕竟...
  • hffhjh111
  • hffhjh111
  • 2016年11月12日 15:17
  • 2516

Java多线程 之 原子性与可见性(八)

1.原子性java中的原子性,是指:原子操作是不能被线程调度机制中断的;操作一旦开始,它一定会在可能发生的“上下文切换”(即切换到其他线程执行)之前执行完毕。 但是千万不要认为“原子操作不需要同步控...
  • fan2012huan
  • fan2012huan
  • 2016年06月19日 19:00
  • 1658

什么是网页原子设计模式(Atomic Design)

我们不是设计页面,我们在设计系统组件。-Stephen HayWe’re not designing pages, we’re designing systems of components.随着网页...
  • iefreer
  • iefreer
  • 2014年04月16日 18:27
  • 4481

Atomic write, 揭开你的面纱

 2016-04-25 晶格思维 晶格思维 晶格思维 晶格思维 微信号 crystalwit 功能介绍 从行业视角介绍IT领域特别是存储领域的新技术、新趋势,强调刨根...
  • tmsi
  • tmsi
  • 2016年04月26日 11:56
  • 1101

原子文件操作 ,不错的思路.AtomicFileOutputStream

每次变更. 先新增一个temp文件. close时,再将文件替换. 确保只有一个线程在更改. public AtomicFileOutputStream(File f) throws Fil...
  • fei33423
  • fei33423
  • 2016年12月07日 23:11
  • 368
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:java线程:Atomic(原子的)
举报原因:
原因补充:

(最多只允许输入30个字)