java并发编程:线程安全管理类--原子操作类--AtomicLongFieldUpdater<T>
1.类 AtomicLongFieldUpdater<T>
public abstract class AtomicLongFieldUpdater<T> extends Object
基于反射的实用工具,可以对指定类的指定 volatile long
字段进行原子更新。此类用于原子数据结构,该结构中同一节点的几个字段都独立受原子更新控制。
注意,此类中 compareAndSet
方法的保证弱于其他原子类中该方法的保证。因为此类不能确保所有使用的字段都适合于原子访问目的,所以对于 compareAndSet 和 set 的其他调用,它仅可以保证原子性和可变语义。
2.构造函数详解
AtomicLongFieldUpdater
protected AtomicLongFieldUpdater()
受保护的无操作构造方法,供子类使用。
3.方法详解
newUpdater
public static <U> AtomicLongFieldUpdater<U> newUpdater(Class<U> tclass,
String fieldName)
- 为对象创建并返回一个具有给定字段的更新器。需要 Class 参数检查反射类型和一般类型是否匹配。
-
- 参数:
tclass
- 保持字段的对象类fieldName
- 要更新的字段名称- 返回:
- 更新器
- 抛出:
IllegalArgumentException
- 如果该字段不是可变的 long 类型RuntimeException
- 如果该类不保持字段,或者是错误的类型,将抛出 RuntimeException 和一个嵌套的基于反射的异常。
compareAndSet
public abstract boolean compareAndSet(T obj,
long expect,
long update)
- 如果当前值
==
预期值,则以原子方式将此更新器所管理的给定对象的字段设置为给定的更新值。对compareAndSet
和set
的其他调用,此方法可以确保原子性,但对于字段中的其他更改则不一定确保原子性。 -
- 参数:
obj
- 有条件地设置其字段的对象expect
- 预期值update
- 新值- 返回:
- 如果成功,则返回 true。
- 抛出:
ClassCastException
- 如果obj
不是类的实例(该类处理在构造方法中建立的字段)。
weakCompareAndSet
public abstract boolean weakCompareAndSet(T obj,
long expect,
long update)
- 如果当前值
==
预期值,则以原子方式将此更新器所管理的给定对象的字段设置为给定的更新值。对compareAndSet
和set
的其他调用,此方法可以确保原子性,但对于字段中的其他更改则不一定确保原子性。可能意外失败并且不提供排序保证,所以只有在很少的情况下才对
compareAndSet
进行适当地选择。 -
- 参数:
obj
- 有条件地设置其字段的对象expect
- 预期值update
- 新值- 返回:
- 如果成功,则返回 true。
- 抛出:
ClassCastException
- 如果obj
不是类的实例(该类处理在构造方法中建立的字段)。
set
public abstract void set(T obj,
long newValue)
- 将此更新器管理的给定对象的字段设置为给定更新值。对于
compareAndSet
的后续调用,此操作可以确保充当可变存储。 -
- 参数:
obj
- 要设置其字段的对象newValue
- 新值
lazySet
public abstract void lazySet(T obj,
long newValue)
- 最后将此更新器管理的给定对象的字段设置为给定更新值。
-
- 参数:
obj
- 要设置其字段的对象newValue
- 新值- 从以下版本开始:
- 1.6
get
public abstract long get(T obj)
- 获取此更新器管理的在给定对象的字段中保持的当前值。
-
- 参数:
obj
- 要获取其字段的对象- 返回:
- 当前值
getAndSet
public long getAndSet(T obj,
long newValue)
- 将此更新器管理的给定对象的字段以原子方式设置为给定值,并返回旧值。
-
- 参数:
obj
- 要获取并设置其字段的对象newValue
- 新值- 返回:
- 以前的值
getAndIncrement
public long getAndIncrement(T obj)
- 以原子方式将此更新器管理的给定对象字段的当前值加 1。
-
- 参数:
obj
- 要获取并设置其字段的对象- 返回:
- 以前的值
getAndDecrement
public long getAndDecrement(T obj)
- 以原子方式将此更新器管理的给定对象字段当前值减 1。
-
- 参数:
obj
- 要获取并设置其字段的对象- 返回:
- 以前的值
getAndAdd
public long getAndAdd(T obj,
long delta)
- 以原子方式将给定值添加到此更新器管理的给定对象的字段的当前值。
-
- 参数:
obj
- 要获取并设置其字段的对象delta
- 要添加的值- 返回:
- 以前的值
incrementAndGet
public long incrementAndGet(T obj)
- 以原子方式将此更新器管理的给定对象字段当前值加 1。
-
- 参数:
obj
- 要获取并设置其字段的对象- 返回:
- 更新的值
decrementAndGet
public long decrementAndGet(T obj)
- 以原子方式将此更新器管理的给定对象字段当前值减 1。
-
- 参数:
obj
- 要获取并设置其字段的对象- 返回:
- 更新的值
addAndGet
public long addAndGet(T obj,
long delta)
- 以原子方式将给定值添加到此更新器管理的给定对象的字段的当前值。
-
- 参数:
obj
- 要获取并设置其字段的对象delta
- 要添加的值- 返回:
- 更新的值
java并发编程:线程安全管理类--原子操作类--AtomicLongFieldUpdater<T>的更多相关文章
- java并发编程 线程基础
java并发编程 线程基础 1. java中的多线程 java是天生多线程的,可以通过启动一个main方法,查看main方法启动的同时有多少线程同时启动 public class OnlyMain { ...
- Java 并发编程 | 线程池详解
原文: https://chenmingyu.top/concurrent-threadpool/ 线程池 线程池用来处理异步任务或者并发执行的任务 优点: 重复利用已创建的线程,减少创建和销毁线程造 ...
- Java并发编程:线程间通信wait、notify
Java并发编程:线程间协作的两种方式:wait.notify.notifyAll和Condition 在前面我们将了很多关于同步的问题,然而在现实中,需要线程之间的协作.比如说最经典的生产者-消费者 ...
- Java并发编程:线程和进程的创建(转)
Java并发编程:如何创建线程? 在前面一篇文章中已经讲述了在进程和线程的由来,今天就来讲一下在Java中如何创建线程,让线程去执行一个子任务.下面先讲述一下Java中的应用程序和进程相关的概念知识, ...
- java并发编程 | 线程详解
个人网站:https://chenmingyu.top/concurrent-thread/ 进程与线程 进程:操作系统在运行一个程序的时候就会为其创建一个进程(比如一个java程序),进程是资源分配 ...
- java并发编程系列二:原子操作/CAS
什么是原子操作 不可被中断的一个或者一系列操作 实现原子操作的方式 Java可以通过锁和循环CAS的方式实现原子操作 CAS( Compare And Swap ) 为什么要有CAS? Compar ...
- Java并发编程——线程池的使用
在前面的文章中,我们使用线程的时候就去创建一个线程,这样实现起来非常简便,但是就会有一个问题: 如果并发的线程数量很多,并且每个线程都是执行一个时间很短的任务就结束了,这样频繁创建线程就会大大降低系统 ...
- Java并发编程——线程池
本文的目录大纲: 一.Java中的ThreadPoolExecutor类 二.深入剖析线程池实现原理 三.使用示例 四.如何合理配置线程池的大小 一.Java中的ThreadPoolExecutor类 ...
- Java并发编程(三)Thread类的使用
一.线程的状态 线程从创建到最终的消亡,要经历若干个状态.一般来说,线程包括以下这几个状态:创建(new).就绪(runnable).运行(running).阻塞(blocked).time wait ...
- [转]JAVA并发编程学习笔记之Unsafe类
1.通过Unsafe类可以分配内存,可以释放内存:类中提供的3个本地方法allocateMemory.reallocateMemory.freeMemory分别用于分配内存,扩充内存和释放内存,与C语 ...
随机推荐
- 使用dll,将image库开放出去
这是很经典的想法了,但是如何来做,不经过摸索不知道细节. 最简单: dll处 #include "stdafx.h" #ifdef _DEBUG #define new ...
- node包管理工具--nvm(windows)
windows 安装nvw-windows 使用nvm工具: windows使用nvm-noinstall.zip安装 nvm-noinstall.zip 这个是绿色免安装版本,但是使用之前需要配置 ...
- HDU 2841 Visible Trees(容斥)题解
题意:有一块(1,1)到(m,n)的地,从(0,0)看能看到几块(如果两块地到看的地方三点一线,后面的地都看不到). 思路:一开始是想不到容斥...后来发现被遮住的地都有一个特点,若(a,b)有gcd ...
- 第七章 对称加密算法--DES
注意:本节内容主要参考自<Java加密与解密的艺术(第2版)>第7章“初等加密算法--对称加密算法” 7.1.对称加密算法 特点: 加密与解密使用同一个密钥 是使用最广的算法 常见对称加密 ...
- 论文笔记之:UNSUPERVISED REPRESENTATION LEARNING WITH DEEP CONVOLUTIONAL GENERATIVE ADVERSARIAL NETWORKS
UNSUPERVISED REPRESENTATION LEARNING WITH DEEP CONVOLUTIONAL GENERATIVE ADVERSARIAL NETWORKS ICLR 2 ...
- C#学习笔记(十一):类和对象
面向对象 为什么要面向对象: 1.和函数一样,把算法封装起来,方便复用 2.更好理解自己和别人写的代码 封装:数据.结构.逻辑的封装,方便复用 多态:同一个对象,同一种指令,不同的行为(反应) 继承: ...
- 如何每日增量加载数据到Hive分区表
如何每日增量加载数据到Hive分区表 hadoop hive shell crontab 加载数据 数据加载到Hive分区表(两个分区,日期(20160316)和小时(10))中 每日加载前一天的日志 ...
- UVa 1395 苗条的生成树(Kruskal+并查集)
https://vjudge.net/problem/UVA-1395 题意: 给出一个n结点的图,求苗条度(最大边减最小边的值)尽量小的生成树. 思路: 主要还是克鲁斯卡尔算法,先仍是按权值排序,对 ...
- Codeforces Beta Round #16 div 2 C.Monitor最大公约数
C. Monitor time limit per test 0.5 second memory limit per test 64 megabytes input standard input ou ...
- awk 提取数字
echo b1c2d3d1e8f9 | awk ' { string=$0 len=length(string) for(i=0; i<=len; i++) { tmp=substr(strin ...