网站首页 > 技术文章 正文
AtomicReferenceArray 类 (java.util.concurrent.atomic. AtomicReferenceArray ) 代表着对象引用数组,在 AtomicReferenceArray 中的Object元素可以原子性的更新,AtomicReferenceArray 中的Object元素同样支持CAS操作。
创建AtomicReferenceArray
可以用两个构造函数中的一个创建AtomicReferenceArray ,第一个构造函数需要一个int类型参数,int参数指定了AtomicReferenceArray 创建的长度,意思就是需要分配多少元素空间,下面是使用这个构造函数创建AtomicReferenceArray :
AtomicReferenceArray array = new AtomicReferenceArray(10);
这个例子创建了一个容量为10的AtomicReferenceArray (有10个Object元素引用的空间),第二个构造函数E[] 数组作为参数,E是一个泛型类型,用这个构造函数创建AtomicReferenceArray 的容量与E[]数组的大小一样,同时所有元素拷贝到AtomicReferenceArray,下面是代码:
Object[] source = new Object[10];
source[5] = "Some string";
AtomicReferenceArray array = new AtomicReferenceArray(source);
这个例子首先创建一个Object[]数组,设置索引为5(第六个)元素的值,然后将此数组作为参数创建AtomicReferenceArray 。同时也可以设置AtomicReferenceArray的泛型类型,下面是设置为String的代码:
String[] source = new String[10];
source[5] = "Some string";
AtomicReferenceArray<String> array =
new AtomicReferenceArray<String>(source);
get()
get()方法获取指定索引值的元素,下面是代码:
Object element = array.get(5);
如果AtomicReferenceArray 设置了泛型类型,那么 get()方法返回泛型类型的对象,比如设置泛型类型为String,那么返回String,下面是代码:
String element = array.get(5);
注意不需要强制转换成String.
set()
set()设置指定索引的元素的值,参数为索引和类型值,下面是代码:
array.set(5, "another object");
第一个参数是索引值,第二个是元素的值。如果AtomicReferenceArray有泛型类型,那么第二个参数的类型与泛型类型一致,否则是Object。
compareAndSet()
AtomicReferenceArray 的compareAndSet()方法,可以将一个期望值与当前值比较,如果相等则更新,下面是代码:
String string1 = "string1";
String string2 = "string2";
String[] source = new String[10];
source[5] = string1;
AtomicReferenceArray<String> array =
new AtomicReferenceArray<String>(source);
array.compareAndSet(5, string1, string2);
这个例子首先创建一个String 数组,设置索引为5(第六个)元素的引用为string1,然后将期望值string1 与索引为5(第六个)元素比较,如果相等,则设置新值为string2的引用,如果没有其他线程改变这个引用,那么设置成功。
更多方法
AtomicReferenceArray的更多方法可以参考JavaDoc。
参考: http://tutorials.jenkov.com/java-util-concurrent/atomicreferencearray.html
http://tutorials.jenkov.com/java-concurrency/compare-and-swap.html
https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/atomic/AtomicReferenceArray.html
猜你喜欢
- 2024-11-03 Hadoop迁移MaxCompute神器之DataX-On-Hadoop使用指南
- 2024-11-03 如何设计一个支撑数亿用户的系统 如何设计一个支撑数亿用户的系统模型
- 2024-11-03 大数据Hadoop之——数据仓库Hive hive数据仓库有什么特点
- 2024-11-03 JAVA并发-AtomicIntegerArray java并发控制的几种方法
- 2024-11-03 Java教程:防缓存穿透利器-布隆滤器(BloomFilter)
- 2024-11-03 浅谈分库分表那些事儿 分库分表技术选型
- 2024-11-03 这一次,彻底弄懂 Java 字节码文件
- 2024-11-03 Oracle数据库扩展语言PL/SQL之集合
- 2024-11-03 如何看懂oracle执行计划(下) oracle的执行计划怎么看
- 2024-11-03 Oracle优化Java字符串内部表示 oracle配置字符集
你 发表评论:
欢迎- 621℃几个Oracle空值处理函数 oracle处理null值的函数
- 614℃Oracle分析函数之Lag和Lead()使用
- 602℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 598℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 594℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 586℃【数据统计分析】详解Oracle分组函数之CUBE
- 575℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 563℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- 前端获取当前时间 (50)
- Oracle RAC (76)
- oracle恢复 (77)
- oracle 删除表 (52)
- oracle 用户名 (80)
- oracle 工具 (55)
- oracle 内存 (55)
- oracle 导出表 (62)
- oracle约束 (54)
- oracle 中文 (51)
- oracle链接 (54)
- oracle的函数 (58)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)