T
- 更新可能なフィールドを保持するオブジェクトの型V
- フィールドの型public abstract class AtomicReferenceFieldUpdater<T,V> extends Object
volatile
参照フィールドの原子更新が可能な、リフレクションベースのユーティリティーです。このクラスは、同一ノードの複数の参照フィールドが独立して原子更新の対象になる原子データ構造での使用を念頭に置いて設計されています。たとえば、ツリーノードは次のように宣言されます。
class Node {
private volatile Node left, right;
private static final AtomicReferenceFieldUpdater<Node, Node> leftUpdater =
AtomicReferenceFieldUpdater.newUpdater(Node.class, Node.class, "left");
private static AtomicReferenceFieldUpdater<Node, Node> rightUpdater =
AtomicReferenceFieldUpdater.newUpdater(Node.class, Node.class, "right");
Node getLeft() { return left; }
boolean compareAndSetLeft(Node expect, Node update) {
return leftUpdater.compareAndSet(this, expect, update);
}
// ... and so on
}
このクラス内の compareAndSet
メソッドの保証は、ほかの原子クラス内のそれよりも弱いことに留意してください。このクラスは、フィールドの使用すべてが原子アクセスに適していることを保証できないため、同じアップデータでの compareAndSet
および set
のほかの呼び出しに関してのみ原子性を保証できます。
修飾子 | コンストラクタと説明 |
---|---|
protected |
AtomicReferenceFieldUpdater()
サブクラスにより使用される、何も行わない protected コンストラクタ。
|
修飾子と型 | メソッドと説明 |
---|---|
abstract boolean |
compareAndSet(T obj, V expect, V update)
「現在の値
== 予想される値」である場合、このアップデータが管理する指定されたオブジェクトのフィールド値を、指定された更新済みの値に原子的に設定します。 |
abstract V |
get(T obj)
このアップデータが管理する指定されたオブジェクトのフィールドが保持する現在値を取得します。
|
V |
getAndSet(T obj, V newValue)
このアップデータにより管理される指定されたオブジェクトのフィールドを指定された値に原始的に設定し、以前の値を返します。
|
abstract void |
lazySet(T obj, V newValue)
このアップデータにより管理される指定されたオブジェクトのフィールドを、指定された更新済みの値に最終的に設定します。
|
static <U,W> AtomicReferenceFieldUpdater<U,W> |
newUpdater(Class<U> tclass, Class<W> vclass, String fieldName)
指定されたフィールドを持つオブジェクトのアップデータを作成して返します。
|
abstract void |
set(T obj, V newValue)
このアップデータにより管理される指定されたオブジェクトのフィールドを、指定された更新済みの値に設定します。
|
abstract boolean |
weakCompareAndSet(T obj, V expect, V update)
「現在の値
== 予想される値」である場合、このアップデータが管理する指定されたオブジェクトのフィールド値を、指定された更新済みの値に原子的に設定します。 |
protected AtomicReferenceFieldUpdater()
public static <U,W> AtomicReferenceFieldUpdater<U,W> newUpdater(Class<U> tclass, Class<W> vclass, String fieldName)
tclass
- フィールドを保持するオブジェクトのクラス。vclass
- フィールドのクラスfieldName
- 更新するフィールドの名前。IllegalArgumentException
- フィールドが揮発性の参照型ではない場合。RuntimeException
- クラスにフィールドが含まれないか、型が不正な場合に、入れ子にされたリフレクションベースの例外がスローされる。public abstract boolean compareAndSet(T obj, V expect, V update)
==
予想される値」である場合、このアップデータが管理する指定されたオブジェクトのフィールド値を、指定された更新済みの値に原子的に設定します。このメソッドは、compareAndSet
および set
に対するほかの呼び出しで原子性を持つことが保証されていますが、フィールド内のほかの変更に関しては必ずしもそうであるとは限りません。obj
- 条件付きでフィールドを設定するオブジェクトexpect
- 予想される値update
- 新しい値public abstract boolean weakCompareAndSet(T obj, V expect, V update)
==
予想される値」である場合、このアップデータが管理する指定されたオブジェクトのフィールド値を、指定された更新済みの値に原子的に設定します。このメソッドは、compareAndSet
および set
に対するほかの呼び出しで原子性を持つことが保証されていますが、フィールド内のほかの変更に関しては必ずしもそうであるとは限りません。
見かけ上失敗する可能性があり、順序付け保証を提供しないため、compareAndSet
の代わりに使用することはほとんどありません。
obj
- 条件付きでフィールドを設定するオブジェクトexpect
- 予想される値update
- 新しい値public abstract void set(T obj, V newValue)
compareAndSet
の呼び出しに関しては、揮発性ストアとして動作することが保証されています。obj
- フィールドを設定するオブジェクトnewValue
- 新しい値public abstract void lazySet(T obj, V newValue)
obj
- フィールドを設定するオブジェクトnewValue
- 新しい値public abstract V get(T obj)
obj
- フィールドを取得するオブジェクト バグまたは機能を送信
詳細な API リファレンスおよび開発者ドキュメントについては、Java SE のドキュメントを参照してください。そのドキュメントには、概念的な概要、用語の定義、回避方法、有効なコード例などの、開発者を対象にしたより詳細な説明が含まれています。
Copyright © 1993, 2013, Oracle and/or its affiliates. All rights reserved.