|
JavaTM 2 Platform Standard Ed. 5.0 |
|||||||||
| 前のクラス 次のクラス | フレームあり フレームなし | |||||||||
| 概要: 入れ子 | フィールド | コンストラクタ | メソッド | 詳細: フィールド | コンストラクタ | メソッド | |||||||||
java.lang.Objectjavax.imageio.spi.ServiceRegistry
public class ServiceRegistry
サービスプロバイダインスタンスのレジストリです。
「サービス」とは、既知のインタフェースおよびクラス (通常は抽象クラス) のセットです。「サービスプロバイダ」とは、特定のサービスの実装です。プロバイダ内のクラスは通常、インタフェースを実装するか、またはサービス自体が定義されたクラスをサブクラス化します。
サービスプロバイダは 1 つまたは複数の「カテゴリ」に格納されます。各カテゴリは、そのすべてのメンバを実装する必要のあるクラスインタフェース (Class オブジェクトにより記述される) で定義されます。カテゴリセットは動的に変更できます。
指定されたリーフクラス (つまり、任意の継承されたクラスやインタフェースではなく、getClass() で返された実際のクラス) の 1 つのインスタンスのみが登録できます。ここで、com.mycompany.mypkg.GreenServiceProvider クラスが com.mycompany.mypkg.MyService インタフェースを実装すると仮定します。GreenServiceProvider インタフェースを登録する場合、これは MyService クラスにより定義されたカテゴリに格納されます。GreenServiceProvider の新しいインスタンスを登録する場合、これは以前のインスタンスを置き替えます。通常、サービスプロバイダオブジェクトは単体であるため、この動作は適切です。
サービスプロバイダを宣言するために、services サブディレクトリが各 JAR ファイルに存在する META-INF ディレクトリ内に配置されます。このディレクトリには、JAR ファイルに 1 つまたは複数の実装クラスを保持する各サービスプロバイダインタフェースに対して 1 つのファイルが含まれます。たとえば、JAR ファイルに javax.someapi.SomeService インタフェースを実装する com.mycompany.mypkg.MyServiceImpl というクラスが含まれる場合、JAR には次の名前のファイルが含まれます。
META-INF/services/javax.someapi.SomeServiceまた、次の行が含まれます。
com.mycompany.mypkg.MyService
サービスプロバイダクラスは軽量で、迅速にロードする必要があります。これらのインタフェースの実装は、他のクラスやネイティブコードに複雑に依存しないようにする必要があります。複雑なサービスの場合の通常のパターンは、負荷の高いサービスに対して軽量なプロキシを登録するというものです。
適切な実行時アクセス権があれば、アプリケーションでレジストリの内容を必要に応じてカスタマイズできます。
サービスプロバイダ宣言の詳細および JAR 形式全般については、 「JAR File Specification」を参照してください。
RegisterableService| 入れ子のクラスの概要 | |
|---|---|
static interface |
ServiceRegistry.Filter
任意の基準に一致するプロバイダを選択するために ServiceRegistry.getServiceProviders で使用される単純なフィルタインタフェースです。 |
| コンストラクタの概要 | |
|---|---|
ServiceRegistry(Iterator<Class<?>> categories)
categories 引数から取り出したカテゴリセットを使用して ServiceRegistry インスタンスを構築します。 |
|
| メソッドの概要 | ||
|---|---|---|
boolean |
contains(Object provider)
provider が現在登録されている場合は true を返します。 |
|
void |
deregisterAll()
現在登録されているすべてのサービスプロバイダオブジェクトを、すべてのカテゴリから登録解除します。 |
|
void |
deregisterAll(Class<?> category)
現在指定されたカテゴリに登録されているサービスプロバイダオブジェクトをすべて登録解除します。 |
|
void |
deregisterServiceProvider(Object provider)
サービスプロバイダオブジェクトを、それを含むすべてのカテゴリから削除します。 |
|
|
deregisterServiceProvider(T provider,
Class<T> category)
指定されたカテゴリからサービスプロバイダオブジェクトを削除します。 |
|
void |
finalize()
ガベージコレクションの前にこのオブジェクトをファイナライズします。 |
|
Iterator<Class<?>> |
getCategories()
現在のカテゴリセットを示す Class オブジェクトの Iterator を返します。 |
|
|
getServiceProviderByClass(Class<T> providerClass)
現在登録されている、指定されたクラス型のプロバイダオブジェクトを返します。 |
|
|
getServiceProviders(Class<T> category,
boolean useOrdering)
指定されたカテゴリ内の登録済みサービスプロバイダをすべて含む Iterator を返します。 |
|
|
getServiceProviders(Class<T> category,
ServiceRegistry.Filter filter,
boolean useOrdering)
指定された ServiceRegistry.Filter オブジェクトの filter メソッドで設定された基準を満たす、指定されたカテゴリ内のサービスプロバイダオブジェクトを含む Iterator を返します。 |
|
static
|
lookupProviders(Class<T> providerClass)
コンテキストクラスローダを使用して、指定されたサービスの使用可能なプロバイダを検出して段階的にインスタンス化します。 |
|
static
|
lookupProviders(Class<T> providerClass,
ClassLoader loader)
指定されたクラスローダを使用して特定のサービスクラスの実装を検索します。 |
|
void |
registerServiceProvider(Object provider)
サービスプロバイダオブジェクトをレジストリに追加します。 |
|
|
registerServiceProvider(T provider,
Class<T> category)
サービスプロバイダオブジェクトをレジストリに追加します。 |
|
void |
registerServiceProviders(Iterator<?> providers)
Iterator から取り込んだ一連のサービスプロバイダオブジェクトをレジストリに追加します。 |
|
|
setOrdering(Class<T> category,
T firstProvider,
T secondProvider)
指定されたカテゴリ内の 2 つのサービスプロバイダオブジェクト間のペアの順序を設定します。 |
|
|
unsetOrdering(Class<T> category,
T firstProvider,
T secondProvider)
指定されたカテゴリの 2 つのサービスプロバイダオブジェクト間のペアの順序を設定します。 |
|
| クラス java.lang.Object から継承されたメソッド |
|---|
clone, equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
| コンストラクタの詳細 |
|---|
public ServiceRegistry(Iterator<Class<?>> categories)
categories 引数から取り出したカテゴリセットを使用して ServiceRegistry インスタンスを構築します。
categories - カテゴリの定義に使用する Class オブジェクトを含む Iterator
IllegalArgumentException - categories が null の場合| メソッドの詳細 |
|---|
public static <T> Iterator<T> lookupProviders(Class<T> providerClass,
ClassLoader loader)
このメソッドは、指定されたサービスクラスの名前を、クラスコメントの記述に従ってプロバイダ構成のファイル名に変換し、指定されたクラスローダの getResources メソッドを使用してその名前を持つ使用可能なファイルすべてを検索します。これらのファイルは次に読み込まれて構文解析され、プロバイダクラス名のリストが作成されます。返された反復子は指定されたクラスローダを使用して、リストの各要素を参照しインスタンス化します。
実行中の Java 仮想マシンに拡張機能をインストールすることが可能であるため、このメソッドは呼び出されるたびに異なる結果を返す場合があります。
providerClass - 検出中のサービスプロバイダのクラスまたはインタフェースを示す Class オブジェクトloader - プロバイダ構成ファイルのロードおよびプロバイダクラスのインスタンス化に使用するクラスローダ。システムクラスローダを使用する場合、またはブートストラップクラスローダで失敗した場合は null
Iterator。プロバイダ構成のファイルが指定された形式に違反するか、またはプロバイダクラスを検出してインスタンス化できない場合、反復子により Error がスローされる
IllegalArgumentException - providerClass が null の場合public static <T> Iterator<T> lookupProviders(Class<T> providerClass)
ClassLoader cl = Thread.currentThread().getContextClassLoader(); return Service.providers(service, cl);
providerClass - 検出中のサービスプロバイダのクラスまたはインタフェースを示す Class オブジェクト
Iterator。プロバイダ構成のファイルが指定された形式に違反するか、またはプロバイダクラスを検出してインスタンス化できない場合、反復子により Error がスローされる
IllegalArgumentException - providerClass が null の場合public Iterator<Class<?>> getCategories()
Class オブジェクトの Iterator を返します。カテゴリが存在しない場合、反復子は空です。
Class オブジェクトを含む Iterator
public <T> boolean registerServiceProvider(T provider,
Class<T> category)
provider が RegisterableService インタフェースを実装する場合、onRegistration メソッドが呼び出されます。その onDeregistration メソッドは、カテゴリの削除やレジストリのガベージコレクトなど、カテゴリから登録解除されるたびに呼び出されます。
provider - 登録されるサービスプロバイダオブジェクトcategory - プロバイダが登録されるカテゴリ
IllegalArgumentException - provider が null の場合
IllegalArgumentException - category に対応するカテゴリが存在しない場合
ClassCastException - プロバイダが category で定義された Class を実装しない場合public void registerServiceProvider(Object provider)
Class を実装するレジストリに存在する各カテゴリ内で関連付けされます。
provider が RegisterableService インタフェースを実装する場合、onRegistration メソッドが登録されるカテゴリごとに一度呼び出されます。その onDeregistration メソッドは、カテゴリから登録解除されるたび、またはレジストリがファイナライズされる際に呼び出されます。
provider - 登録されるサービスプロバイダオブジェクト
IllegalArgumentException - provider が null の場合public void registerServiceProviders(Iterator<?> providers)
Iterator から取り込んだ一連のサービスプロバイダオブジェクトをレジストリに追加します。各プロバイダは、Class を実装するレジストリに存在する各カテゴリ内で関連付けされます。
RegisterableService インタフェースを実装する provider の各エントリの場合、onRegistration メソッドが登録されるカテゴリごとに一度呼び出されます。その onDeregistration メソッドは、カテゴリから登録解除されるたび、またはレジストリがファイナライズされる際に呼び出されます。
providers - 登録されるサービスプロバイダオブジェクトを含む反復子
IllegalArgumentException - providers が null であるか、null エントリを含む場合
public <T> boolean deregisterServiceProvider(T provider,
Class<T> category)
false を返します。そうでない場合は、true を返します。provider と同じクラスのオブジェクトであっても provider と等しくない (== で比較) 場合、登録は解除されません。
provider が RegisterableService インスタンスを実装する場合、その onDeregistration メソッドが呼び出されます。
provider - 登録解除されるサービスプロバイダオブジェクトcategory - プロバイダが登録解除されるカテゴリ
true、そうでない場合は false
IllegalArgumentException - provider が null の場合
IllegalArgumentException - category に対応するカテゴリが存在しない場合
ClassCastException - プロバイダが category で定義されたクラスを実装しない場合public void deregisterServiceProvider(Object provider)
provider - 登録解除されるサービスプロバイダオブジェクト
IllegalArgumentException - provider が null の場合public boolean contains(Object provider)
provider が現在登録されている場合は true を返します。
provider - 照会されるサービスプロバイダオブジェクト
true
IllegalArgumentException - provider が null の場合
public <T> Iterator<T> getServiceProviders(Class<T> category,
boolean useOrdering)
Iterator を返します。useOrdering が false の場合、反復子はすべてのサービスプロバイダオブジェクトを任意の順序で返します。それ以外の場合、順番は設定されたペアの順序付けすべてを反映します。ペアの順序付けのグラフにサイクルが含まれる場合、サイクルに所属するプロバイダはどれも返されません。
category - 取得元のカテゴリuseOrdering - 返されるオブジェクトの順番にペアの順序付けを反映する場合は true
Iterator (大抵はその順番通り)
IllegalArgumentException - category に対応するカテゴリが存在しない場合
public <T> Iterator<T> getServiceProviders(Class<T> category,
ServiceRegistry.Filter filter,
boolean useOrdering)
ServiceRegistry.Filter オブジェクトの filter メソッドで設定された基準を満たす、指定されたカテゴリ内のサービスプロバイダオブジェクトを含む Iterator を返します。
useOrdering 引数により、getServiceProviders(Class, boolean) と同じ規則を使用して結果の順序付けが制御されます。
category - 取得元のカテゴリfilter - filter メソッドが呼び出される ServiceRegistry.Filter インスタンスuseOrdering - 返されるオブジェクトの順番にペアの順序付けを反映する場合は true
Iterator (大抵はその順番通り)
IllegalArgumentException - category に対応するカテゴリが存在しない場合public <T> T getServiceProviderByClass(Class<T> providerClass)
null を返します。
providerClass - 目的とするサービスプロバイダオブジェクトの Class
Class 型のサービスプロバイダオブジェクト。存在しない場合は null
IllegalArgumentException - providerClass が null の場合
public <T> boolean setOrdering(Class<T> category,
T firstProvider,
T secondProvider)
false を返します。プロバイダが以前に逆方向に順序付けされた場合、その順序は削除されます。
順序は、useOrdering 引数が true の場合に、getServiceProviders メソッドにより使用されます。
category - 優先度を設定するカテゴリを示す Class オブジェクトfirstProvider - 優先されるプロバイダsecondProvider - firstProvider が優先されるプロバイダ
true
IllegalArgumentException - プロバイダが null か、または同じオブジェクトの場合
IllegalArgumentException - category に対応するカテゴリが存在しない場合
public <T> boolean unsetOrdering(Class<T> category,
T firstProvider,
T secondProvider)
false を返します。
順序は、useOrdering 引数が true の場合に、getServiceProviders メソッドにより使用されます。
category - 優先度の設定が解除されるカテゴリを示す Class オブジェクトfirstProvider - 以前の優先プロバイダsecondProvider - firstProvider が以前優先されていたプロバイダ
true
IllegalArgumentException - プロバイダが null か、または同じオブジェクトの場合
IllegalArgumentException - category に対応するカテゴリが存在しない場合public void deregisterAll(Class<?> category)
category - 空にするカテゴリ
IllegalArgumentException - category に対応するカテゴリが存在しない場合public void deregisterAll()
public void finalize()
throws Throwable
deregisterAll メソッドを呼び出して、現在登録されているサービスプロバイダをすべて登録解除します。このメソッドを、アプリケーションコードから呼び出してはなりません。
Object 内の finalizeThrowable - スーパークラスのファイナライズ時にエラーが発生した場合
|
JavaTM 2 Platform Standard Ed. 5.0 |
|||||||||
| 前のクラス 次のクラス | フレームあり フレームなし | |||||||||
| 概要: 入れ子 | フィールド | コンストラクタ | メソッド | 詳細: フィールド | コンストラクタ | メソッド | |||||||||
Copyright 2004 Sun Microsystems, Inc. All rights reserved. Use is subject to license terms. Documentation Redistribution Policy も参照してください。