【Java源码计划】package-info<rt.jar_java.util.concurrent.atomic.package-info>>

package-info

这个package-info.java 来源于java.util.concurrent.atomic

这个包下面是一些用来支持单变量的无锁线程安全。本质上来说,这些类只是将volatile的值和字段还有数组元素的概念扩展到了那些需要提供类似compareAndSet(expectedValue, updateValue)也就是CAS原子更新操作的对象中。这个方法的作用是如果参数中(不同类参数不一样)的expectedValue字段和当前持有的这个值是一样的,这个值就会被更新为updateValue值,并且在更新成功后返回true,注意返回失败只有当expectedValue和当前元素不一样的时候才会返回false。

在这个包中的类还包含无条件的设置方法,可以直接将元素更新为指定的值,同时还有弱条件的原则更新操作weakcompareandset,这样的话从接口上就有CAS原子更新,弱原子更新,以及无条件更新三种。

正确的按照规范使用这些方法可以使用现代处理器上可用的高效的机器级的原子指令。然后,在某些平台上这种支持可能需要平台内部的某种锁定。因此,不能严格的保证方法是非阻塞的,也就是说线程在执行操作之前可能会暂时的阻塞住。

以下这些类
java.util.concurrent.atomic.AtomicBoolean
java.util.concurrent.atomic.AtomicInteger,
java.util.concurrent.atomic.AtomicLong,
java.util.concurrent.atomic.AtomicReference
每一个都提供了对对应类型的单个变量的访问和更新,同时还提供一些与这些类型相关的方法。举个例子,AtomicInteger和AtomicLong提供了自增的方法,可以通过下面这个例子可以按序生成一个序列

class Sequencer {
   private final AtomicLong sequenceNumber
     = new AtomicLong(0);
   public long next() {
    return sequenceNumber.getAndIncrement();
   }
 }}

相似的,定义一个类似的工具方法也很方便,像getAndIncrement一样,把原子操作应用到元素上。例如:

long getAndTransform(AtomicLong var) {
  long prev, next;
  do {
    prev = var.get();
    //调用一些操作后得到next
    next = transform(prev);
    //CAS确保这个操作原子完成
  } while (!var.compareAndSet(prev, next));
  return prev; // return next; for transformAndGet
 }}
 
 long transform(long input){
   //在这处理需要原子保证的操作
 }

注意 原子访问和更新的效果通常遵循volatiles的规则
下面是oracle关于这个规则的文档
The Java Language Specification (17.4 Memory Model)

简单来说:

  • get方法和读取一个volatile变量的内存效果一样
  • set方法和写(包括分配)一个volatile变量的内存效果一样
  • lazySet方法和写(包括分配)一个volatile变量的内存效果一样,但是,这个方法允许对后续(对之前的不行)内存操作进行重新排序这些操作本身不会对非Volatile描述的普通写入进行重排序。在整个使用的上下文中,lazySet一般用于取消引用的时候,为了垃圾回收,这个引用就不再能访问了。
  • weakCompareAndSet 原子性的进行读和有条件的进行写,但是不会创建任何happens-before(这部分放到内存里面说)屏障,这就意味着对于任何非weakCompareAndSet得目标的读和写的先后顺序不提供任何担保。
  • compareAndSet 以及相似的读和更新的操作,比如getAndIncrement都和读写volatile变量的内存效果是一样的。
  • 出了对于单个元素的这种操作的类以外,这个包下面还包括一些Updater的类,这些类可以用于提供对任何给定字段或者给定类的CAS操作

分开说说下面的这些类或者方法

  • 下面这几个类都是基于反射提供对关联字段的访问。主要用于这样的原子数据结构——位于同一个节点中的多个独立原子更新的volatile字段。这些类对于在何时和如何使用原子更新上提供了更好的灵活性,但是这个灵活性的代价是基于反射的这种设置会使得操作更加笨拙,使用时也更加不方便,提供的保证也更弱
    • java.util.concurrent.atomic.AtomicReferenceFieldUpdater
    • java.util.concurrent.atomic.AtomicIntegerFieldUpdater
    • java.util.concurrent.atomic.AtomicLongFieldUpdater
  • 下面这几个类进一步将原子操作扩展到对应类型的数组中。同时这些类对于提供普通数组所不具备的volatile访问语义方面也很重要。
    • java.util.concurrent.atomic.AtomicIntegerArray
    • java.util.concurrent.atomic.AtomicLongArray
    • java.util.concurrent.atomic.AtomicReferenceArray

关于weakCompareAndSet:
原子类还支持方法weakcompareandset,这种方法的适用性有限。在某些平台上正常情况下,weak版本可能比compareandset更有效,但不同之处在于weak compareandset方法的任何给定调用都有可能返回莫名其妙的错误 false(也就是说,没有明显的原因告诉你为啥false了)。返回错误的时候如果需要可以选择重试一次,重试是否能够成功取决于变量持有expectedValue,并且没有其他线程试图修改变量的时候,重试操作最后会成功。(比如,返回false可能是由于内存争用造成的,所以这个时候返回的false可能是跟预期值和当前值不相等无关)。另外,weakcompareandset不提供和通常的同步操作需要的顺序保证。但是这个方法比较适合用于更新那种和happen-before顺序无关的统计变量或者计数器。

关于AtomicMarkableReference
java.util.concurrent.atomic.AtomicMarkableReference,这个类把一个布尔类型和一个引用类型关联起来,这个类可以有很多应用,例如,这个位可以用于在一个数据结构中标识这个引用被逻辑删除了。

关于AtomicStampedReference
java.util.concurrent.atomic.AtomicStampedReference,这个类把一个整形和一个引用类型关联起来,这个的应用可以是用于标识一系列的更新的版本号。

原子类主要设计给那些无阻塞数据结构和相关基础类。注意, compareAndSet方法不是一个一般意义上对锁的替代,而是只有在针对对象的单个关键变量的更新时比较适用。

注意 原子类不是对 java.lang.Integer和类似类的一个通用的替换类,这些类也会定义hashcode和compareto,但是由于原子变量是主要用于变化的,也就是说这个变量是期望变化的,这就使得这些变量不适合作为哈希表的key。另外,这个包里面只提供了那些比较通用的类。比如没有byte的原子类,如果的确是需要的这种不常见的操作,可以使用atomicinteger保存byte值,并进行适当的强制转换就可以了。

还可以用java.lang.Float#floatToRawIntBits和java.lang.Float#intBitsToFloat进行转换,类似的double可以用java.lang.Double#doubleToRawLongBits和java.lang.Double#longBitsToDouble进行转换

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,080评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,422评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,630评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,554评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,662评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,856评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,014评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,752评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,212评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,541评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,687评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,347评论 4 331
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,973评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,777评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,006评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,406评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,576评论 2 349

推荐阅读更多精彩内容