クラス ForkJoinPoolFactoryBean
- 実装されたすべてのインターフェース:
DisposableBean
、FactoryBean<ForkJoinPoolSE>
、InitializingBean
ForkJoinPool
SE を作成して公開する Spring FactoryBean
。- 導入:
- 3.1
- 作成者:
- Juergen Hoeller
フィールドサマリー
インターフェース org.springframework.beans.factory.FactoryBean から継承されたフィールド
OBJECT_TYPE_ATTRIBUTE
コンストラクターのサマリー
メソッドのサマリー
修飾子と型メソッド説明void
void
destroy()
Bean の破棄時に、包含BeanFactory
によって呼び出されます。このファクトリによって管理されるオブジェクトのインスタンス(おそらく共有または独立)を返します。ClassSE<?>
この FactoryBean が作成するオブジェクトの型、または事前に不明な場合はnull
を返します。boolean
このファクトリによって管理されるオブジェクトはシングルトンですか? つまり、FactoryBean.getObject()
は常に同じオブジェクト(キャッシュ可能な参照)を返しますか?void
setAsyncMode
(boolean asyncMode) 結合されないフォークされたタスクに対してローカルの先入れ先出しスケジューリングモードを確立するかどうかを指定します。void
setAwaitTerminationSeconds
(int awaitTerminationSeconds) 残りのコンテナーが引き続きシャットダウンする前に、残りのタスクが実行を完了するのを待つために、シャットダウン時にこの ForkJoinPool がブロックする最大秒数を設定します。void
setCommonPool
(boolean commonPool) JDK 8 の「共通」ForkJoinPool
SE を公開するかどうかを設定します。void
setParallelism
(int parallelism) 並列度を指定します。void
setThreadFactory
(ForkJoinPool.ForkJoinWorkerThreadFactorySE threadFactory) 新しい ForkJoinWorkerThreads を作成するためのファクトリを設定します。void
setUncaughtExceptionHandler
(Thread.UncaughtExceptionHandlerSE uncaughtExceptionHandler) タスクの実行中に発生した回復不可能なエラーが原因で終了する内部ワーカースレッドのハンドラーを設定します。
コンストラクターの詳細
ForkJoinPoolFactoryBean
public ForkJoinPoolFactoryBean()
メソッドの詳細
setCommonPool
public void setCommonPool(boolean commonPool) JDK 8 の「共通」ForkJoinPool
SE を公開するかどうかを設定します。デフォルトは "false" で、この FactoryBean の
"parallelism"
、"threadFactory"
、"uncaughtExceptionHandler"
、"asyncMode"
プロパティに基づいてローカルForkJoinPool
SE インスタンスを作成します。注意 : このフラグを "true" に設定すると、この FactoryBean の他のすべてのプロパティが事実上無視され、代わりに共有の共通 JDK
ForkJoinPool
SE が再利用されます。これは JDK 8 の良い選択ですが、ForkJoinPool の動作をカスタマイズするアプリケーションの機能、特にカスタムスレッドの使用を削除します。- 導入:
- 3.2
- 関連事項:
setParallelism
public void setParallelism(int parallelism) 並列度を指定します。デフォルトはRuntime.availableProcessors()
です。setThreadFactory
新しい ForkJoinWorkerThreads を作成するためのファクトリを設定します。デフォルトはForkJoinPool.defaultForkJoinWorkerThreadFactory
SE です。setUncaughtExceptionHandler
タスクの実行中に発生した回復不可能なエラーが原因で終了する内部ワーカースレッドのハンドラーを設定します。デフォルトはなしです。setAsyncMode
public void setAsyncMode(boolean asyncMode) 結合されないフォークされたタスクに対して、ローカルの先入れ先出しスケジューリングモードを確立するかどうかを指定します。このモード (asyncMode =true
) は、ワーカースレッドがイベントスタイルの非同期タスクのみを処理するアプリケーションでは、デフォルトのローカルスタックベースモードよりも適切な場合があります。デフォルトはfalse
です。setAwaitTerminationSeconds
public void setAwaitTerminationSeconds(int awaitTerminationSeconds) 残りのコンテナーが引き続きシャットダウンする前に、残りのタスクが実行を完了するのを待つために、シャットダウン時にこの ForkJoinPool がブロックする最大秒数を設定します。これは、残りのタスクがコンテナーによって管理されている他のリソースへのアクセスを必要とする可能性がある場合に特に役立ちます。デフォルトでは、この ForkJoinPool はタスクの終了をまったく待ちません。残りのコンテナーのシャットダウンと並行して、進行中のすべてのタスクとキュー内の残りのすべてのタスクを完全に実行し続けます。対照的に、このプロパティを使用して終了待機期間を指定した場合、このエグゼキュータは、タスクの終了のために指定された時間(最大)待機します。
この機能は
"commonPool"
モードでも機能することに注意してください。その場合、基になる ForkJoinPool は実際には終了しませんが、すべてのタスクが終了するまで待機します。afterPropertiesSet
public void afterPropertiesSet()インターフェースからコピーされた説明:InitializingBean
すべての Bean プロパティを設定し、BeanFactoryAware
、ApplicationContextAware
などを満たした後、包含BeanFactory
によって呼び出されます。このメソッドにより、Bean インスタンスは、すべての Bean プロパティが設定されたときに、その全体的な構成の検証と最終的な初期化を実行できます。
- 次で指定:
- インターフェース
InitializingBean
のafterPropertiesSet
getObject
インターフェースからコピーされた説明:FactoryBean
このファクトリによって管理されるオブジェクトのインスタンス(おそらく共有または独立)を返します。BeanFactory
と同様に、これにより、シングルトンとプロトタイプの両方のデザインパターンをサポートできます。この FactoryBean が呼び出し時にまだ完全に初期化されていない場合(たとえば、循環参照に関係しているため)、対応する
FactoryBeanNotInitializedException
をスローします。Spring 2.0 以降、FactoryBeans は
null
オブジェクトを返すことができます。ファクトリはこれを通常の値として使用します。この場合、FactoryBeanNotInitializedException はスローされません。FactoryBean の実装では、必要に応じて FactoryBeanNotInitializedException 自体をすぐにスローすることをお勧めします。- 次で指定:
- インターフェース
FactoryBean<ForkJoinPoolSE>
のgetObject
- 戻り値:
- Bean のインスタンス (
null
にすることができます) - 関連事項:
getObjectType
インターフェースからコピーされた説明:FactoryBean
この FactoryBean が作成するオブジェクトの型、または事前に不明な場合はnull
を返します。これにより、たとえばオートワイヤーなどで、オブジェクトをインスタンス化せずに特定の型の Bean を確認できます。
シングルトンオブジェクトを作成している実装の場合、このメソッドはシングルトンの作成を可能な限り回避しようとします。むしろ、事前に型を推定する必要があります。プロトタイプの場合、ここで意味のある型を返すこともお勧めします。
このメソッドは、この FactoryBean が完全に初期化される前に呼び出すことができます。初期化中に作成された状態に依存しないでください。もちろん、利用可能な場合はそのような状態を引き続き使用できます。
注意 : オートワイヤーは、ここで
null
を返す FactoryBeans を単に無視します。FactoryBean の現在の状態を使用して、このメソッドを適切に実装することを強くお勧めします。- 次で指定:
- インターフェース
FactoryBean<ForkJoinPoolSE>
のgetObjectType
- 戻り値:
- この FactoryBean が作成するオブジェクトの型、または呼び出し時に不明な場合は
null
- 関連事項:
isSingleton
public boolean isSingleton()インターフェースからコピーされた説明:FactoryBean
このファクトリによって管理されるオブジェクトはシングルトンですか? つまり、FactoryBean.getObject()
は常に同じオブジェクト(キャッシュ可能な参照)を返しますか?注意 : FactoryBean がシングルトンオブジェクトを保持することを示す場合、
getObject()
から返されたオブジェクトは所有 BeanFactory によってキャッシュされる可能性があります。FactoryBean が常に同じ参照を公開しない限り、true
を返さないでください。FactoryBean 自体のシングルトンステータスは、通常、所有する BeanFactory によって提供されます。通常、そこではシングルトンとして定義する必要があります。
注意 :
false
を返すこのメソッドは、返されるオブジェクトが独立したインスタンスであることを必ずしも示しません。拡張SmartFactoryBean
インターフェースの実装は、SmartFactoryBean.isPrototype()
メソッドを通じて独立したインスタンスを明示的に示す場合があります。この拡張インターフェースを実装しないプレーンなFactoryBean
実装は、isSingleton()
実装がfalse
を返す場合、常に独立したインスタンスを返すと単純に想定されます。FactoryBean
は通常シングルトンインスタンスを管理するため、デフォルトの実装ではtrue
が返されます。- 次で指定:
- インターフェース
FactoryBean<ForkJoinPoolSE>
のisSingleton
- 戻り値:
- 公開されたオブジェクトがシングルトンかどうか
- 関連事項:
destroy
public void destroy()インターフェースからコピーされた説明:DisposableBean
Bean の破棄時に、包含BeanFactory
によって呼び出されます。- 次で指定:
- インターフェース
DisposableBean
のdestroy