モジュール java.base
パッケージ java.lang.module

インタフェースModuleReader

すべてのスーパー・インタフェース:
AutoCloseable, Closeable

public interface ModuleReader extends Closeable
モジュールのコンテンツへのアクセスを提供します。

モジュール・リーダーは、モジュールがロードされているかどうかに関係なく、モジュール内のリソースへのアクセスが必要な場合を対象としています。 たとえば、ファイル・システム上のパッケージ・モジュールのコレクションをスキャンするフレームワークでは、モジュール・リーダーを使用して、各モジュール内の特定のリソースにアクセスできます。 モジュール・リーダーは、モジュールからクラスおよびリソースをロードするClassLoader実装でも使用されます。

モジュール内のリソースは、/で区切られたパス文字列である抽象名で識別されます。 たとえば、モジュールjava.baseには、通常、java.lang.Objectのクラス・ファイルであるリソース"java/lang/Object.class"がある場合があります。 モジュール・リーダーは、モジュール・コンテンツのディレクトリをリソース(モジュール・リーダー固有かどうか)として扱います。 モジュール・コンテンツにリソースとして配置できるディレクトリが含まれている場合、その名前はスラッシュ('/')で終わります。 ディレクトリは、末尾のスラッシュを削除する名前で配置することもできます。

ModuleReaderは作成時にopenで、closeメソッドを呼び出して閉じます。 モジュール・リーダーのクローズに失敗すると、リソース・リークが発生する可能性があります。 try-with-resources文は、モジュール・リーダーを閉じるために役立つ構成を提供します。

ModuleReader実装では、モジュール内のリソースにアクセスする権限が必要になる場合があります。 したがって、findopenreadおよびlistメソッドは、セキュリティ・マネージャによってアクセスが拒否された場合に SecurityExceptionをスローすることがあります。

実装要件:
ModuleReaderの実装は、抽象リソース名をパッケージ・モジュールまたはファイル・システム内のリソースのロケーションに変換する際に十分に注意する必要があります。 実装では、...などの要素、ファイル・セパレータを含む要素または空の要素を"見つかりません"として扱うことをお薦めします。 より一般的には、リソース名がlistメソッドが返す要素のストリームにない場合は、不整合を回避するために、リソースを"見つかりません"として処理する必要があります。
導入されたバージョン:
9
関連項目:
  • メソッドのサマリー

    修飾子と型
    メソッド
    説明
    void
    モジュール・リーダーを閉じます。
    find(String name)
    リソースを検索し、モジュール内のリソースにURIを返します。
    モジュールの内容を一覧表示し、モジュール内のすべてのリソースの名前である要素のストリームを返します。
    open(String name)
    リソースを開き、モジュール内のリソースを読み取るための入力ストリームを返します。
    read(String name)
    リソースを読み取り、リソースの内容を含むバイト・バッファを返します。
    default void
    Byteバッファを解放します。
  • メソッドの詳細

    • find

      Optional<URI> find(String name) throws IOException
      リソースを検索し、モジュール内のリソースにURIを返します。

      モジュール・リーダーが名前によってディレクトリが特定されていると判断できる場合、結果のURIはスラッシュ('/')で終了します。

      パラメータ:
      name - 読書のために開くリソースの名前
      戻り値:
      リソースへのURI。リソースが見つからない場合、またはURIを構築してリソースを見つけることができない場合は空のOptional
      例外:
      IOException - I/Oエラーが発生した場合、またはモジュール・リーダーが閉じている場合
      SecurityException - セキュリティ・マネージャによって拒否された場合
      関連項目:
    • open

      default Optional<InputStream> open(String name) throws IOException
      リソースを開き、モジュール内のリソースを読み取るための入力ストリームを返します。

      モジュール・リーダーのクローズ後に使用された入力ストリームの動作は、実装固有であるため指定されません。

      実装要件:
      デフォルトの実装では、findメソッドを呼び出して、リソースへのURIを取得します。 見つかった場合、URLを構築し、リソースへの接続をオープンしようとします。
      パラメータ:
      name - 読書のために開くリソースの名前
      戻り値:
      リソースを読み取るための入力ストリーム、または見つからなければ空のOptional
      例外:
      IOException - I/Oエラーが発生した場合、またはモジュール・リーダーが閉じている場合
      SecurityException - セキュリティ・マネージャによって拒否された場合
    • read

      default Optional<ByteBuffer> read(String name) throws IOException
      リソースを読み取り、リソースの内容を含むバイト・バッファを返します。 戻されるバッファの位置にある要素はリソースの最初のバイトで、バッファの制限にある要素はリソースの最後のバイトです。 使用後は、releaseメソッドを起動する必要があります。 releaseメソッドの起動に失敗すると、リソース・リークが発生する可能性があります。
      APIのノート:
      このメソッドは、高パフォーマンスのクラス・ロードを対象としています。 (または意図された)は、2GB以上の可能性がある任意の大規模なリソースを読み取ることができません。 このメソッドをreleaseメソッドと組み合せて使用する理由は、モジュール・リーダー実装でバッファを効率的に管理できるようにすることです。
      実装要件:
      デフォルトの実装では、openメソッドが呼び出され、入力ストリームからバイト・バッファにすべてのバイトが読み取られます。
      パラメータ:
      name - 読み取るリソースの名前
      戻り値:
      リソースの内容を含むバイト・バッファ、または見つからなければ空のOptional
      例外:
      IOException - I/Oエラーが発生した場合、またはモジュール・リーダーが閉じている場合
      SecurityException - セキュリティ・マネージャによって拒否された場合
      OutOfMemoryError - リソースがInteger.MAX_VALUEより大きい場合、バイト・バッファの最大容量
      関連項目:
    • release

      default void release(ByteBuffer bb)
      Byteバッファを解放します。 このメソッドは、readメソッドによって返されたバッファの内容を消費した後に起動する必要があります。 すでに解放されているバッファを解放するためにこのメソッドが呼び出されたときの動作、またはModuleReaderが閉じられた後にバッファを解放するために呼び出されたときの動作は、実装固有であるため指定されません。
      実装要件:
      デフォルトの実装では、バイト・バッファがnullかどうかをチェックする以外は何も行いません。
      パラメータ:
      bb - 解放するバイト・バッファ
    • list

      Stream<String> list() throws IOException
      モジュールの内容を一覧表示し、モジュール内のすべてのリソースの名前である要素のストリームを返します。 要素のストリームにモジュール内のディレクトリに対応する名前が含まれているかどうかは、モジュール・リーダー固有です。

      レイジー実装では、ストリームを使用してモジュールの内容をリストするときに、IOExceptionがスローされることがあります。 これが発生すると、IOExceptionUncheckedIOExceptionにラップされ、アクセスを試行したメソッドからスローされます。 SecurityExceptionは、ストリームを使用してモジュールの内容をリストするときにスローされ、セキュリティ・マネージャによってアクセスが拒否されることもあります。

      返されるストリームには、モジュール内の1つ以上の開いているディレクトリへの参照が含まれている場合があります。 ディレクトリは、ストリームを閉じて閉じます。

      モジュール・リーダーのクローズ後に使用された場合のストリームの動作は、実装固有であるため指定されません。

      APIのノート:
      このメソッドはtry-with-resources文または同様の制御構造内で使用して、ストリームによって参照されるオープン・ディレクトリが、ストリームの操作が完了した後にすぐに閉じられるようにする必要があります。
      戻り値:
      モジュール内のすべてのリソースの名前である要素のストリーム
      例外:
      IOException - I/Oエラーが発生した場合、またはモジュール・リーダーが閉じている場合
      SecurityException - セキュリティ・マネージャによって拒否された場合
    • close

      void close() throws IOException
      モジュール・リーダーを閉じます。 一旦閉じられると、IOExceptionを投げることによって、リソースを見つけたり読んだりする後続の呼び出しが失敗します。

      モジュール・リーダーを非同期的にクローズ可能にする必要はありません。 スレッドがリソースを読み込み、別のスレッドがcloseメソッドを呼び出すと、読取り操作が完了するまで2番目のスレッドがブロックされることがあります。

      定義:
      close、インタフェースAutoCloseable
      定義:
      close、インタフェースCloseable
      例外:
      IOException - 入出力エラーが発生した場合