数组也可以实现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. Filter command

    1. grep   egrep    fgrep 2. sort sort -d sort -n sort -r sort -f 3. uniq uniq -d uniq -u uniq -c 4. ...

  2. 【UVA】1596 Bug Hunt(模拟)

    题目 题目     分析 算是个模拟吧     代码 #include <bits/stdc++.h> using namespace std; map<int,int> a[ ...

  3. 编写一个参数JavaScript函数parseQueryString,它的用途是把url参数解析为一个对象

    var url = "http://www.taobao.com/index.php?key0=0&key1=1&key2=2............."; var ...

  4. php if判断

    php if判断 例子如下: True是否等于False 变量haq是不是老婆呢? <?php $ts=true; $f=false; if (isset($ts)&&isset ...

  5. PHP5 ini配置文件优化

    1.1使用tmpfs作为缓存加速缓存的文件目录 [root@php-node1 ~]# mount -t tmpfs tmpfs /dev/shm/ -o size=256m [root@php-no ...

  6. optparse模块

    optparse模块主要是用来对参数的记录,相对来说比较灵活, 例子代码如下: #!/usr/bin/env python from optparse import OptionParser usag ...

  7. No serializer found for class org.hibernate.proxy.pojo.javassist.JavassistLazyInitializer解决方法

    org.codehaus.jackson.map.JsonMappingException: No serializer found for class org.hibernate.proxy.poj ...

  8. objective-C: NSString应该用initWithFormat? 还是 stringWithFormat?

    今天在看书上的一段代码时,发现NSString实例化时,有时用的是initWithFormat方法,有时用的是stringWithFormat,到底应该如何选择呢? 区别: 1.initWithFor ...

  9. XP下安装IIS的图文教程(无光盘)

    IIS5.1安装文件包下载地址:http://yunpan.cn/QzBZGugw84wEr 安装记录: 1. 将IIS5.1安装文件包解压 2. 开始-->控制面板-->添加/删除程序- ...

  10. AlphaTesting

    [Alpha Testing] The alpha test is a last chance to reject a pixel from being written to the screen. ...