public abstract class AbstractRequestAttributesScope extends ObjectSE implements Scope
RequestAttributes
オブジェクトの特定のスコープから読み取る抽象 Scope
実装。 サブクラスは、属性を読み取る RequestAttributes
スコープをこのクラスに指示するために、getScope()
を実装する必要があるだけです。
サブクラスは、get(java.lang.String, org.springframework.beans.factory.ObjectFactory<?>)
および remove(java.lang.String)
メソッドをオーバーライドして、このスーパークラスへのコールバックに同期を追加することができます。
コンストラクターと説明 |
---|
AbstractRequestAttributesScope() |
修飾子と型 | メソッドと説明 |
---|---|
ObjectSE | get(StringSE name, ObjectFactory<?> objectFactory) 基になるスコープから指定された名前のオブジェクトを返します。基になるストレージメカニズムで見つからない場合は creating it 。 |
protected abstract int | getScope() 実際のターゲットスコープを決定するテンプレートメソッド。 |
void | registerDestructionCallback(StringSE name, RunnableSE callback) スコープ内の指定されたオブジェクトの破棄(またはスコープが個々のオブジェクトを破棄せず、その全体で終了する場合はスコープ全体の破棄)で実行されるコールバックを登録します。 |
ObjectSE | remove(StringSE name) 指定された name を持つオブジェクトを基になるスコープから削除します。 |
ObjectSE | resolveContextualObject(StringSE key) 指定されたキーがある場合、そのコンテキストオブジェクトを解決します。 |
cloneSE, equalsSE, finalizeSE, getClassSE, hashCodeSE, notifySE, notifyAllSE, toStringSE, waitSE, waitSE, waitSE
getConversationId
public ObjectSE get(StringSE name, ObjectFactory<?> objectFactory)
Scope
creating it
。これは、Scope の中心的な操作であり、絶対に必要な唯一の操作です。
Scope
の get
name
- 取得するオブジェクトの名前 objectFactory
- 基になるストレージメカニズムに存在しない場合、スコープオブジェクトの作成に使用する ObjectFactory
null
)@Nullable public ObjectSE remove(StringSE name)
Scope
name
を持つオブジェクトを基になるスコープから削除します。 オブジェクトが見つからなかった場合、null
を返します。それ以外の場合は、削除された Object
を返します。
実装は、指定されたオブジェクトの登録された破棄コールバックも削除する必要があることに注意してください。ただし、この場合、登録された破棄コールバックを実行する必要はありません。オブジェクトは呼び出し元によって破棄されるためです(適切な場合)。
注: これはオプションの操作です。実装は、オブジェクトの明示的な削除をサポートしていない場合、UnsupportedOperationException
SE をスローする場合があります。
Scope
の remove
name
- 削除するオブジェクトの名前 null
Scope.registerDestructionCallback(java.lang.String, java.lang.Runnable)
public void registerDestructionCallback(StringSE name, RunnableSE callback)
Scope
注: これはオプションの操作です。このメソッドは、実際の破棄構成(DisposableBean、destroy-method、DestructionAwareBeanPostProcessor)を持つスコープ付き Bean に対してのみ呼び出されます。実装は、適切なタイミングで特定のコールバックを実行するために最善を尽くす必要があります。そのようなコールバックが基礎となるランタイム環境によってまったくサポートされていない場合、コールバックは無視され、対応する警告がログに記録される必要があります。
「破棄」とは、アプリケーションによって明示的に削除された個々のスコープオブジェクトではなく、スコープ自体のライフサイクルの一部としてオブジェクトを自動的に破棄することです。スコープ付きオブジェクトがこのファサードの Scope.remove(String)
メソッドを介して削除された場合、削除されたオブジェクトが再利用されるか手動で破棄されると仮定して、登録されている破棄コールバックも削除する必要があります。
Scope
の registerDestructionCallback
name
- 破棄コールバックを実行するオブジェクトの名前 callback
- 実行される破棄コールバック。渡された Runnable は例外をスローしないため、try-catch ブロックを囲むことなく安全に実行できることに注意してください。さらに、Runnable は通常、そのターゲットオブジェクトも直列化可能であれば、直列化可能です。DisposableBean
, AbstractBeanDefinition.getDestroyMethodName()
, DestructionAwareBeanPostProcessor
@Nullable public ObjectSE resolveContextualObject(StringSE key)
Scope
Scope
の resolveContextualObject
key
- コンテキストキー null
protected abstract int getScope()
RequestAttributes
定数の形式)RequestAttributes.SCOPE_REQUEST
, RequestAttributes.SCOPE_SESSION