java.util.concurrent.atomic.atomicintegerarray类提供了可以以原子方式读取和写入的底层int数组的操作,还包含高级原子操作。 atomicintegerarray支持对底层int数组变量的原子操作。 它具有获取和设置方法,如在变量上的读取和写入。 也就是说,一个集合与同一变量上的任何后续get相关联。 原子compareandset方法也具有这些内存一致性功能。
| 序号 | 方法 | 描述 |
|---|---|---|
| 1 | public int addandget(int i, int delta) |
原子地将给定的值添加到索引i的元素。 |
| 2 | public boolean compareandset(int i, int expect, int update) |
如果当前值==期望值,则将位置i处的元素原子设置为给定的更新值。 |
| 3 | public int decrementandget(int i) |
索引i处的元素原子并自减1。 |
| 4 | public int get(int i) |
获取位置i的当前值。 |
| 5 | public int getandadd(int i, int delta) |
原子地将给定的值添加到索引i的元素。 |
| 6 | public int getanddecrement(int i) |
索引i处的元素原子并自减1,并返回旧值。 |
| 7 | public int getandincrement(int i) |
将位置i处的元素原子设置为给定值,并返回旧值。 |
| 8 | public int getandset(int i, int newvalue) |
将位置i处的元素原子设置为给定值,并返回旧值。 |
| 9 | public int incrementandget(int i) |
在索引i处以原子方式自增元素。 |
| 10 | public void lazyset(int i, int newvalue) |
最终将位置i处的元素设置为给定值。 |
| 11 | public int length() |
返回数组的长度。 |
| 12 | public void set(int i, int newvalue) |
将位置i处的元素设置为给定值。 |
| 13 | public string tostring() |
返回数组的当前值的string表示形式。 |
| 14 | public boolean weakcompareandset(int i, int expect, int update) |
如果当前值==期望值,则将位置i处的元素原子设置为给定的更新值。 |
以下testthread程序显示了基于线程的环境中atomicintegerarray变量的使用。
import java.util.concurrent.atomic.atomicintegerarray;
public class testthread {
private static atomicintegerarray atomicintegerarray = new atomicintegerarray(10);
public static void main(final string[] arguments) throws interruptedexception {
for (int i=0; i<atomicintegerarray.length(); i++) {
atomicintegerarray.set(i, 1);
}
thread t1 = new thread(new increment());
thread t2 = new thread(new compare());
t1.start();
t2.start();
t1.join();
t2.join();
system.out.println("values: ");
for (int i=0; i<atomicintegerarray.length(); i++) {
system.out.print(atomicintegerarray.get(i) + " ");
}
}
static class increment implements runnable {
public void run() {
for(int i=0; i<atomicintegerarray.length(); i++) {
int add = atomicintegerarray.incrementandget(i);
system.out.println("thread " + thread.currentthread().getid()
+ ", index " +i + ", value: "+ add);
}
}
}
static class compare implements runnable {
public void run() {
for(int i=0; i<atomicintegerarray.length(); i++) {
boolean swapped = atomicintegerarray.compareandset(i, 2, 3);
if(swapped){
system.out.println("thread " + thread.currentthread().getid()
+ ", index " +i + ", value: 3");
}
}
}
}
}
这将产生以下结果 -
thread 10, index 0, value: 2
thread 10, index 1, value: 2
thread 10, index 2, value: 2
thread 11, index 0, value: 3
thread 10, index 3, value: 2
thread 11, index 1, value: 3
thread 11, index 2, value: 3
thread 10, index 4, value: 2
thread 11, index 3, value: 3
thread 10, index 5, value: 2
thread 10, index 6, value: 2
thread 11, index 4, value: 3
thread 10, index 7, value: 2
thread 11, index 5, value: 3
thread 10, index 8, value: 2
thread 11, index 6, value: 3
thread 10, index 9, value: 2
thread 11, index 7, value: 3
thread 11, index 8, value: 3
thread 11, index 9, value: 3
values:
3 3 3 3 3 3 3 3 3 3