public class SimpleThreadScope extends java.lang.Object implements Scope
Scope 実装。 注意 : このスレッドスコープは、一般的なコンテキストではデフォルトでは登録されません。代わりに、ConfigurableBeanFactory.registerScope(java.lang.String, org.springframework.beans.factory.config.Scope) または CustomScopeConfigurer Bean のいずれかを使用して、セットアップのスコープキーに明示的に割り当てる必要があります。
SimpleThreadScope は、それに関連付けられているオブジェクトをクリーンアップしません。そのため、通常、Web 環境では RequestScope を使用することをお勧めします。
破棄コールバックをサポートするスレッドベースの Scope の実装については、カスタムスレッドスコープモジュールの例による Spring を参照してください。
スレッドスコープの元のプロトタイプを提出してくれた Eugene Kuleshov に感謝します!
RequestScope| コンストラクターと説明 |
|---|
SimpleThreadScope() |
| 修飾子と型 | メソッドと説明 |
|---|---|
java.lang.Object | get(java.lang.String name, ObjectFactory<?> objectFactory) 基になるスコープから指定された名前のオブジェクトを返します。基になるストレージメカニズムで見つからない場合は creating it。 |
java.lang.String | getConversationId() 存在する場合、現在の基礎となるスコープの会話 ID を返します。 |
void | registerDestructionCallback(java.lang.String name, java.lang.Runnable callback) スコープ内の指定されたオブジェクトの破棄(またはスコープが個々のオブジェクトを破棄せず、その全体で終了する場合はスコープ全体の破棄)で実行されるコールバックを登録します。 |
java.lang.Object | remove(java.lang.String name) 指定された name を持つオブジェクトを基になるスコープから削除します。 |
java.lang.Object | resolveContextualObject(java.lang.String key) 指定されたキーがある場合、そのコンテキストオブジェクトを解決します。 |
public java.lang.Object get(java.lang.String name,
ObjectFactory<?> objectFactory)Scopecreating it。これは、Scope の中心的な操作であり、絶対に必要な唯一の操作です。
Scope の get name - 取得するオブジェクトの名前 objectFactory - 基になるストレージメカニズムに存在しない場合、スコープオブジェクトの作成に使用する ObjectFactorynull ではない)@Nullable public java.lang.Object remove(java.lang.String name)
Scopename を持つオブジェクトを基になるスコープから削除します。 オブジェクトが見つからなかった場合、null を返します。それ以外の場合は、削除された Object を返します。
実装は、指定されたオブジェクトの登録された破棄コールバックも削除する必要があることに注意してください。ただし、この場合、登録された破棄コールバックを実行する必要はありません。オブジェクトは呼び出し元によって破棄されるためです(適切な場合)。
注: これはオプションの操作です。オブジェクトの明示的な削除をサポートしていない場合、実装は UnsupportedOperationException をスローする場合があります。
Scope の remove name - 削除するオブジェクトの名前 null Scope.registerDestructionCallback(java.lang.String, java.lang.Runnable)public void registerDestructionCallback(java.lang.String name,
java.lang.Runnable callback)Scope注: これはオプションの操作です。このメソッドは、実際の破棄構成(DisposableBean、destroy-method、DestructionAwareBeanPostProcessor)を持つスコープ付き Bean に対してのみ呼び出されます。実装は、適切なタイミングで特定のコールバックを実行するために最善を尽くす必要があります。そのようなコールバックが基礎となるランタイム環境によってまったくサポートされていない場合、コールバックは無視され、対応する警告がログに記録される必要があります。
「破棄」とは、アプリケーションによって明示的に削除された個々のスコープオブジェクトではなく、スコープ自体のライフサイクルの一部としてオブジェクトを自動的に破棄することです。スコープ付きオブジェクトがこのファサードの Scope.remove(String) メソッドを介して削除された場合、削除されたオブジェクトが再利用されるか手動で破棄されると仮定して、登録されている破棄コールバックも削除する必要があります。
Scope の registerDestructionCallback name - 破棄コールバックを実行するオブジェクトの名前 callback - 実行される破棄コールバック。渡された Runnable は例外をスローしないため、try-catch ブロックを囲むことなく安全に実行できることに注意してください。さらに、Runnable は通常、そのターゲットオブジェクトも直列化可能であれば、直列化可能です。DisposableBean, AbstractBeanDefinition.getDestroyMethodName(), DestructionAwareBeanPostProcessor@Nullable public java.lang.Object resolveContextualObject(java.lang.String key)
ScopeScope の resolveContextualObject key - コンテキストキー null public java.lang.String getConversationId()
Scope 会話 ID の正確な意味は、基礎となるストレージメカニズムによって異なります。セッションスコープのオブジェクトの場合、会話 ID は通常 session IDEE と等しい(または派生する)でしょう。セッション全体に含まれるカスタム会話の場合、現在の会話の特定の ID が適切です。
注: これはオプションの操作です。基になるストレージメカニズムにこのような ID の明らかな候補がない場合、このメソッドの実装で null を返すことは完全に有効です。
Scope の getConversationId null