Java concurrency之AtomicLong原子类.pdf

  1. 1、本文档共11页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Java concurrency之AtomicLong原子类

Java concurrency 之 AtomicLong 原子类 A t o m i c L o n g 介 绍 和 函 数 列 表 AtomicLong 是作用是对长整形进行原子操作。 在 32 位操作系统中,64 位的 long 和 double 变量由于会被 JVM 当作两个分离的 32 位来进行操作,所以不具有原子性。 而使用 AtomicLong 能让 long 的操作保持原子型。 AtomicLong 函数列表 // 构造函数 AtomicLong() // 创建值为 initialValue 的AtomicLong 对象 AtomicLong(long initialValue) // 以原子方式设置当前值为 newValue。 final void set(long newValue) // 获取当前值 final long get() // 以原子方式将当前值减 1 ,并返回减1 后的值。等价于 “--num” final long decrementAndGet() // 以原子方式将当前值减 1 ,并返回减1 前的值。等价于 “num--” final long getAndDecrement() // 以原子方式将当前值加 1 ,并返回加1 后的值。等价于 “++num” final long incrementAndGet() // 以原子方式将当前值加 1 ,并返回加1 前的值。等价于 “num++” final long getAndIncrement() // 以原子方式将 delta 与当前值相加 ,并返回相加后的值。 final long addAndGet(long delta) // 以原子方式将 delta 添加到当前值,并返回相加前的值。 final long getAndAdd(long delta) // 如果当前值 == expect ,则以原子方式将该值设置为update。成功返回true ,否则返回false ,并且不修改原值。 final boolean compareAndSet(long expect, long update) // 以原子方式设置当前值为 newValue ,并返回旧值。 final long getAndSet(long newValue) // 返回当前值对应的 int 值 int intValue() // 获取当前值对应的 long 值 long longValue() // 以 float 形式返回当前值 float floatValue() // 以 double 形式返回当前值 1 / 11 double doubleValue() // 最后设置为给定值。延时设置变量值,这个等价于 set()方法,但是由于字段是 volatile 类型的,因此次字段的修改会比普 通字段(非 volatile 字段)有稍微的性能延时(尽管可以忽略),所以如果不是想立即读取设置的新值,允许在 “后台”修 改值,那么此方法就很有用。如果还是难以理解,这里就类似于启动一个后台线程如执行修改新值的任务,原线程就不等待 修改结果立即返回(这种解释其实是不正确的,但是可以这么理解)。 final void lazySet(long newValue) // 如果当前值 == 预期值,则以原子方式将该设置为给定的更新值。JSR 规范中说:以原子方式读取和有条件地写入变量 但不 创建任何 happen-before 排序,因此不提供与除 weakCompareAndSet 目标外任何变量以前或后续读取或写入操 作有关的任何保证。大意就是说调用 weakCompareAndSet 时并不能保证不存在 happen-before 的发生(也就是可能存在 指令重排序导致此操作失败)。但是从 Java 源码来看,其实此方法并没有实现 JSR 规范的要求,最后效果和 compareAndSet 是等效的,都调用了 pareAndSwapInt()完成操作。 final boolean weakCompareAndSet(long expect, long update) A t o m i c L o n g 源 码 分 析 ( 基 于 J D K 1 . 7 . 0 _ 4 0 ) AtomicLong 的完整源码 1 /*

文档评论(0)

yan698698 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档