1.类 AtomicIntegerArray
可以用原子方式更新其元素的 int
数组
2.构造函数详解
AtomicIntegerArray
public AtomicIntegerArray(int length)
- 创建给定长度的新 AtomicIntegerArray。
- 参数:
length
- 该数组的长度
AtomicIntegerArray
public AtomicIntegerArray(int[] array)
- 创建与给定数组具有相同长度的新 AtomicIntegerArray,并从给定数组复制其所有元素。
- 参数:
array
- 从中复制元素的数组- 抛出:
NullPointerException
- 如果数组为 null
3.方法详解
length
public final int length()
- 返回该数组的长度。
- 返回:
- 该数组的长度
get
public final int get(int i)
- 获取位置
i
的当前值。 - 参数:
i
- 索引- 返回:
- 当前值
set
public final void set(int i, int newValue)
- 将位置
i
的元素设置为给定值。 - 参数:
i
- 索引newValue
- 新值
lazySet
public final void lazySet(int i, int newValue)
- 最后将位置
i
的元素设置为给定值。 - 参数:
i
- 索引newValue
- 新值- 从以下版本开始:
- 1.6
getAndSet
public final int getAndSet(int i, int newValue)
- 将位置
i
的元素以原子方式设置为给定值,并返回旧值。 - 参数:
i
- 索引newValue
- 新值- 返回:
- 以前的值
compareAndSet
public final boolean compareAndSet(int i, int expect, int update)
- 如果当前值
==
预期值,则以原子方式将位置i
的元素设置为给定的更新值。 - 参数:
i
- 索引expect
- 预期值update
- 新值- 返回:
- 如果成功,则返回 true。返回 false 指示实际值与预期值不相等。
weakCompareAndSet
public final boolean weakCompareAndSet(int i, int expect, int update)
- 如果当前值
==
预期值,则以原子方式将位置i
的元素设置为给定的更新值。可能意外失败并且不提供排序保证,所以只是在很少的情况下才对
compareAndSet
进行适当地选择。 - 参数:
i
- 索引expect
- 预期值update
- 新值- 返回:
- 如果成功,则返回 true。
getAndIncrement
public final int getAndIncrement(int i)
- 以原子方式将索引
i
的元素加 1。 - 参数:
i
- 索引- 返回:
- 以前的值
getAndDecrement
public final int getAndDecrement(int i)
- 以原子方式将索引
i
的元素减 1。 - 参数:
i
- 索引- 返回:
- 以前的值
getAndAdd
public final int getAndAdd(int i, int delta)
- 以原子方式将给定值与索引
i
的元素相加。 - 参数:
i
- 索引delta
- 要加上的值- 返回:
- 以前的值
incrementAndGet
public final int incrementAndGet(int i)
- 以原子方式将索引
i
的元素加 1。 - 参数:
i
- 索引- 返回:
- 更新的值
decrementAndGet
public final int decrementAndGet(int i)
- 以原子方式将索引
i
的元素减 1。 - 参数:
i
- 索引- 返回:
- 更新的值
addAndGet
public final int addAndGet(int i, int delta)
- 以原子方式将给定值与索引
i
的元素相加。 - 参数:
i
- 索引delta
- 要加上的值- 返回:
- 更新的值
toString
public String toString()