数组也可以实现cas操作,有以下几个类以及用法如下:

public class AtomicTntegerArrayTest {
public static void main(String[] args) {
AtomicIntegerArray atomicIntegerArray=new AtomicIntegerArray(3);
AtomicLongArray atomicIntegerArray1=new AtomicLongArray(3);
AtomicReferenceArray atomicReferenceArray=new AtomicReferenceArray(3);
//1.获取长度 length
System.out.println("方法1");
System.out.println(atomicIntegerArray.length());
//2.将下标i的值设置为 newValue,并且返回旧的值 getAndSet
System.out.println("方法2");
System.out.println(atomicIntegerArray.getAndSet(0,1));
System.out.println(atomicIntegerArray.get(0));
//3.进行CAS操作,比较修改compareAndSet
System.out.println("方法3");
boolean b = atomicIntegerArray.compareAndSet(0, 1, 2);
boolean b1 = atomicIntegerArray.compareAndSet(0, 1, 2);
System.out.println(b);
System.out.println(b1);
//4.将数组的第几个,加1 getAndIncrement,减1 getAndDecrement,返回旧值
System.out.println("方法4");
System.out.println(atomicIntegerArray.getAndIncrement(0));;
System.out.println(atomicIntegerArray.get(0));
System.out.println(atomicIntegerArray.getAndDecrement(0));
System.out.println(atomicIntegerArray.get(0));
//5.将第几个元素 加多少addAndGet 返回新值和getAndAdd 返回旧值
System.out.println("方法5");
System.out.println(atomicIntegerArray.get(0));
System.out.println(atomicIntegerArray.addAndGet(0,3));
System.out.println(atomicIntegerArray.get(0));
System.out.println(atomicIntegerArray.getAndAdd(0, 3));
System.out.println(atomicIntegerArray.get(0));
}
}

运行结果为:

方法1
3
方法2
0
1
方法3
true
false
方法4
2
3
3
2
方法5
2
5
5
5
8

4.4.6 数组也能无锁:AtomicIntegerArray的更多相关文章

  1. 【实战Java高并发程序设计 4】数组也能无锁:AtomicIntegerArray

    除了提供基本数据类型外,JDK还为我们准备了数组等复合结构.当前可用的原子数组有:AtomicIntegerArray.AtomicLongArray和AtomicReferenceArray,分别表 ...

  2. 【实战Java高并发程序设计6】挑战无锁算法:无锁的Vector实现

    [实战Java高并发程序设计 1]Java中的指针:Unsafe类 [实战Java高并发程序设计 2]无锁的对象引用:AtomicReference [实战Java高并发程序设计 3]带有时间戳的对象 ...

  3. 一个可无限伸缩且无ABA问题的无锁队列

    关于无锁队列,详细的介绍请参考陈硕先生的<无锁队列的实现>一文.然进一步,如何实现一个不限node数目即能够无限伸缩的无锁队列,即是本文的要旨. 无锁队列有两种实现形式,分别是数组与链表. ...

  4. [转]透过 Linux 内核看无锁编程

    非阻塞型同步 (Non-blocking Synchronization) 简介 如何正确有效的保护共享数据是编写并行程序必须面临的一个难题,通常的手段就是同步.同步可分为阻塞型同步(Blocking ...

  5. 实现无锁的栈与队列(5):Hazard Pointer

    两年多以前随手写了点与 lock free 相关的笔记:1,2,3,4,质量都不是很高其实(读者见谅),但两年来陆陆续续竟也有些阅读量了(可见剑走偏锋的技巧是多容易吸引眼球).笔记当中在解决内存释放和 ...

  6. zeromq源码分析笔记之无锁队列ypipe_t(3)

    在上一篇中说到了mailbox_t的底层实际上使用了管道ypipe_t来存储命令.而ypipe_t实质上是一个无锁队列,其底层使用了yqueue_t队列,ypipe_t是对yueue_t的再包装,所以 ...

  7. boost 无锁队列

    一哥们翻译的boost的无锁队列的官方文档 原文地址:http://blog.csdn.net/great3779/article/details/8765103 Boost_1_53_0终于迎来了久 ...

  8. 无锁模式的Vector

    这两天学习无锁的并发模式,发现相比于传统的 同步加锁相比,有两点好处1.无锁 模式 相比于 传统的 同步加锁  提高了性能 2.无锁模式 是天然的死锁免疫 下来介绍无锁的Vector--- LockF ...

  9. Java高并发之无锁与Atomic源码分析

    目录 CAS原理 AtomicInteger Unsafe AtomicReference AtomicStampedReference AtomicIntegerArray AtomicIntege ...

随机推荐

  1. jredis 客户端 使用

    redis学习及实践3---Jedis.JedisPool.Jedis分布式实例介绍 Java中使用Jedis操作Redis Redis客户端:Jedis

  2. 第三章 k8s cluster环境创建

    1  用如下方法安装指定版本的docker,但是我的环境会报错 # 安装rpm apt install rpm # 下载 RPM 包, docker 版本 wget https://download. ...

  3. Druid.io系列(二):基本概念与架构

    原文链接:  https://blog.csdn.net/njpjsoftdev/article/details/52955788 在介绍Druid架构之前,我们先结合有关OLAP的基本原理来理解Dr ...

  4. 浅谈OPP

    了解Java或C#等面向对象编程语言的的程序员比较熟悉类和对象以及OOP. 一谈起OOP,就会想起教科书式的OOP概念:封装.继承.多态.粗浅的解释封装就是对数据进行隐藏:继承就是子类继承父类(cla ...

  5. JS中的定时器

    在JS中的定时器分两种: 1,setTimeout() 2,setInterval() setTimeout(): 只在指定时间后执行一次: function hello(){ alert('hell ...

  6. Android APP压力测试实战

    环境准备: Android SDK Python   压测实战步骤 1.在手机开发者工具中,将USB调试选上 2.确认手机,电脑成功连接(通过adb devices) 3.安装测试app(adb in ...

  7. CentOS7.6安装稳定版Nginx

    官网地址:http://nginx.org/en/linux_packages.html#RHEL-CentOS 需先安装依赖:sudo yum install -y yum-utils 安装开始: ...

  8. linux weather

  9. 【转】运输层TCP协议详细介绍

    TCP是TCP/IP协议族中非常复杂的一个协议.它具有以下特点: 1:面向连接的运输层协议.在使用TCP协议之前,首先需要建立TCP连接.传送数据完毕后,必须释放已经建立的TCP连接. 2:一条TCP ...

  10. 关于springboot中文件上传,properties配置

    spring.http.multipart.enabled=true #默认支持文件上传. spring.http.multipart.file-size-threshold=0 #支持文件写入磁盘. ...