T
- 更新可能なフィールドを保持するオブジェクトの型public abstract class AtomicIntegerFieldUpdater<T> extends Object
volatile int
フィールドの原子更新が可能な、リフレクション・ベースのユーティリティです。このクラスは、同一ノードの複数フィールドが独立して原子更新の対象になる原子データ構造で使用する目的で設計されています。
このクラス内のcompareAndSet
メソッドの保証は、ほかの原子クラス内のそれよりも弱いことに留意してください。このクラスは、フィールドの使用すべてが原子アクセスに適していることを保証できないため、同じアップデータでのcompareAndSet
およびset
のほかの呼出しに関してのみ原子性を保証できます。
修飾子 | コンストラクタと説明 |
---|---|
protected |
AtomicIntegerFieldUpdater()
サブクラスにより使用される、何も行わないprotectedコンストラクタ。
|
修飾子と型 | メソッドと説明 |
---|---|
int |
accumulateAndGet(T obj, int x, IntBinaryOperator accumulatorFunction)
このアップデータが管理する指定されたオブジェクトのフィールドを、指定された関数を現在の値と指定された値に適用した結果で原子的に更新し、更新された値を返します。
|
int |
addAndGet(T obj, int delta)
このアップデータが管理する指定されたオブジェクトのフィールドの現在値に、指定された値を原子的に追加します。
|
abstract boolean |
compareAndSet(T obj, int expect, int update)
「現在の値
== 予想される値」である場合、このアップデータが管理する指定されたオブジェクトのフィールド値を、指定された更新済みの値に原子的に設定します。 |
int |
decrementAndGet(T obj)
このアップデータが管理する指定されたオブジェクトのフィールドの現在値を原子的に1だけ減分します。
|
abstract int |
get(T obj)
このアップデータが管理する指定されたオブジェクトのフィールドが保持する現在値を取得します。
|
int |
getAndAccumulate(T obj, int x, IntBinaryOperator accumulatorFunction)
このアップデータが管理する指定されたオブジェクトのフィールドを、指定された関数を現在の値と指定された値に適用した結果で原子的に更新し、前の値を返します。
|
int |
getAndAdd(T obj, int delta)
このアップデータが管理する指定されたオブジェクトのフィールドの現在値に、指定された値を原子的に追加します。
|
int |
getAndDecrement(T obj)
このアップデータが管理する指定されたオブジェクトのフィールドの現在値を原子的に1だけ減分します。
|
int |
getAndIncrement(T obj)
このアップデータが管理する指定されたオブジェクトのフィールドの現在値を原子的に1だけ増分します。
|
int |
getAndSet(T obj, int newValue)
このアップデータにより管理される指定されたオブジェクトのフィールドを指定された値に原始的に設定し、以前の値を返します。
|
int |
getAndUpdate(T obj, IntUnaryOperator updateFunction)
このアップデータが管理する指定されたオブジェクトのフィールドを、指定された関数を適用した結果で原子的に更新し、前の値を返します。
|
int |
incrementAndGet(T obj)
このアップデータが管理する指定されたオブジェクトのフィールドの現在値を原子的に1だけ増分します。
|
abstract void |
lazySet(T obj, int newValue)
このアップデータにより管理される指定されたオブジェクトのフィールドを、指定された更新済みの値に最終的に設定します。
|
static <U> AtomicIntegerFieldUpdater<U> |
newUpdater(Class<U> tclass, String fieldName)
指定されたフィールドを持つオブジェクトのアップデータを作成して返します。
|
abstract void |
set(T obj, int newValue)
このアップデータにより管理される指定されたオブジェクトのフィールドを、指定された更新済みの値に設定します。
|
int |
updateAndGet(T obj, IntUnaryOperator updateFunction)
このアップデータが管理する指定されたオブジェクトのフィールドを、指定された関数を適用した結果で原子的に更新し、更新された値を返します。
|
abstract boolean |
weakCompareAndSet(T obj, int expect, int update)
「現在の値
== 予想される値」である場合、このアップデータが管理する指定されたオブジェクトのフィールド値を、指定された更新済みの値に原子的に設定します。 |
protected AtomicIntegerFieldUpdater()
public static <U> AtomicIntegerFieldUpdater<U> newUpdater(Class<U> tclass, String fieldName)
U
- tclassのインスタンスの型tclass
- フィールドを保持するオブジェクトのクラスfieldName
- 更新するフィールドの名前IllegalArgumentException
- フィールドが揮発性の整数型ではない場合RuntimeException
- クラスにフィールドが含まれないかクラスの型が不正な場合、あるいは、呼出し元がJava言語アクセス制御に従ってフィールドにアクセスできない場合は、入れ子にされたリフレクション・ベースの例外がスローされる。public abstract boolean compareAndSet(T obj, int expect, int update)
==
予想される値」である場合、このアップデータが管理する指定されたオブジェクトのフィールド値を、指定された更新済みの値に原子的に設定します。このメソッドは、compareAndSet
およびset
に対するほかの呼出しで原子性を持つことが保証されていますが、フィールド内のほかの変更に関しては必ずしもそうであるとは限りません。obj
- 条件付きでフィールドを設定するオブジェクトexpect
- 予想される値update
- 新しい値true
ClassCastException
- obj
がコンストラクタ内で確立されたフィールドを処理するクラスのインスタンスではない場合public abstract boolean weakCompareAndSet(T obj, int expect, int update)
==
予想される値」である場合、このアップデータが管理する指定されたオブジェクトのフィールド値を、指定された更新済みの値に原子的に設定します。このメソッドは、compareAndSet
およびset
に対するほかの呼出しで原子性を持つことが保証されていますが、フィールド内のほかの変更に関しては必ずしもそうであるとは限りません。
見かけ上失敗する可能性があり、順序付け保証を提供しないため、compareAndSet
の代わりに使用することはほとんどありません。
obj
- 条件付きでフィールドを設定するオブジェクトexpect
- 予想される値update
- 新しい値true
ClassCastException
- obj
がコンストラクタ内で確立されたフィールドを処理するクラスのインスタンスではない場合public abstract void set(T obj, int newValue)
compareAndSet
の呼出しに関しては、揮発性ストアとして動作することが保証されています。obj
- フィールドを設定するオブジェクトnewValue
- 新しい値public abstract void lazySet(T obj, int newValue)
obj
- フィールドを設定するオブジェクトnewValue
- 新しい値public abstract int get(T obj)
obj
- フィールドを取得するオブジェクトpublic int getAndSet(T obj, int newValue)
obj
- フィールドを取得および設定するオブジェクトnewValue
- 新しい値public int getAndIncrement(T obj)
obj
- フィールドを取得および設定するオブジェクトpublic int getAndDecrement(T obj)
obj
- フィールドを取得および設定するオブジェクトpublic int getAndAdd(T obj, int delta)
obj
- フィールドを取得および設定するオブジェクトdelta
- 追加する値public int incrementAndGet(T obj)
obj
- フィールドを取得および設定するオブジェクトpublic int decrementAndGet(T obj)
obj
- フィールドを取得および設定するオブジェクトpublic int addAndGet(T obj, int delta)
obj
- フィールドを取得および設定するオブジェクトdelta
- 追加する値public final int getAndUpdate(T obj, IntUnaryOperator updateFunction)
obj
- フィールドを取得および設定するオブジェクトupdateFunction
- 副作用のない関数public final int updateAndGet(T obj, IntUnaryOperator updateFunction)
obj
- フィールドを取得および設定するオブジェクトupdateFunction
- 副作用のない関数public final int getAndAccumulate(T obj, int x, IntBinaryOperator accumulatorFunction)
obj
- フィールドを取得および設定するオブジェクトx
- 更新値accumulatorFunction
- 2つの引数を取る、副作用のない関数public final int accumulateAndGet(T obj, int x, IntBinaryOperator accumulatorFunction)
obj
- フィールドを取得および設定するオブジェクトx
- 更新値accumulatorFunction
- 2つの引数を取る、副作用のない関数 バグまたは機能を送信
詳細なAPIリファレンスおよび開発者ドキュメントについては、Java SEのドキュメントを参照してください。そのドキュメントには、概念的な概要、用語の定義、回避方法、有効なコード例などの、開発者を対象にしたより詳細な説明が含まれています。
Copyright© 1993, 2014, Oracle and/or its affiliates. All rights reserved.