目次|前|次 |
META-INF/services
ディレクトリが含まれます。JARファイルに格納されたクラスにより実装される各サービス・プロバイダ・インタフェースごとに、サービス・プロバイダ・インタフェースの完全指定のクラス名を名前として付けられたファイルが、services
ディレクトリ内に置かれます。そのファイルには、JARファイル内に存在する実装クラスの完全指定のクラス名を、1行に1つずつ組み込む必要があります。たとえば、JARファイルにjavax.imageio.spi.ImageReaderSpi
インタフェースを実装するcom.mycompany.mypackage.MyImageReaderSpi
というサービス・プロバイダ・クラスが含まれる場合、com.mycompany.mypackage.MyImageReaderSpi
の行を含むMETA-INF/services/javax.imageio.spi.ImageReaderSpi
という名前のファイルが必要です。
Image I/O APIは、クラス・パス上に見つかるすべてのJARファイルを自動的に調査して、Image I/Oプラグインを含むJARファイルを識別します。見つかった各プラグインについて、そのサービス・プロバイダ・クラスのインスタンスが1つ生成され、実行時レジストリ・クラスであるjavax.iamgeio.spi.IIORegistry
内に格納されます。
アプリケーション・クラス・パス(CLASSPATH
変数を使って設定するパス)上のJARファイル、または任意の場所にあるJARファイル(たとえば、ネットワークURL経由で入手できるファイル)を、アプリケーションからロードすることもできます。起動時間を短くするため、これらのファイルはデフォルトではロードされません。
javax.imageio.spi.IIORegistry
クラスは、インストールされたプラグインを登録解除したり、新しいプラグインを登録したりするために、実行時に使用することもできます。特に、ClassLoader
を使用してネットワーク経由でプラグインをロードしたあと、そのプラグインを登録して、ローカルにインストールされたプラグインとまったく同じようにして使用することができます。
大部分のアプリケーションは、実行時レジストリを直接に取り扱う必要はありません。代わりに、適切なプラグインを自動的に検索するjavax.imageio.ImageIO
クラス内の簡易メソッドを利用できます。