- すべての実装されたインタフェース:
- Comparable<ModuleDescriptor>
 モジュール記述子は、名前付きモジュールを記述し、その各コンポーネントを取得するためのメソッドを定義します。 Java仮想マシン内の名前付きモジュールのモジュール記述子は、Module getDescriptorメソッドを呼び出すことによって取得されます。 モジュール記述子は、ModuleDescriptor.Builderクラスを使用するか、ここで定義されたreadメソッドを使用して(module-info.class)モジュール宣言のバイナリ形式を読み込むことによっても作成できます。  
 モジュール記述子は、normal、open、またはautomaticモジュールを記述します。 「ノーマル」モジュールおよびオープン・モジュールでは、「依存関係」、exported-packages、useまたは「提供」が提供するサービス、およびその他のコンポーネントについて説明します。 「ノーマル」モジュールは、open固有のパッケージの場合があります。 オープン・モジュールのモジュール記述子はオープン・パッケージ(そのopensメソッドは空のセットを返します)を宣言しませんが、Java仮想マシンでインスタンス化すると、すべてのパッケージがオープンしているかのように扱われます。 自動モジュールのモジュール記述子は依存関係( java.baseの必須の依存関係を除いて)を宣言しておらず、エクスポート・パッケージまたはオープン・パッケージも宣言しません。 自動モジュールは、構成内の他のすべてのモジュールを読み取るために、解決中に特別な処理を受け取ります。 自動モジュールがJava仮想マシンでインスタンス化されると、名前のないモジュールがすべて読み込まれ、すべてのパッケージがエクスポートされ、開いているかのように扱われます。  
 ModuleDescriptorオブジェクトは、複数の同時スレッドで使用するために不変で安全です。
- 導入されたバージョン:
- 9
- 関連項目:
- 
ネストされたクラスのサマリーネストされたクラス修飾子と型クラス説明static final classModuleDescriptorオブジェクトを構築するためのビルダー。static final classモジュールによってエクスポートされたパッケージは、修飾されているか、または修飾されていない可能性があります。static enumモジュール上の修飾子。static final classモジュールによってオープンされたパッケージは、修飾されているか、または修飾されていない可能性があります。static final classモジュールが1つ以上の実装を提供するサービス。static final classモジュールへの依存性。static final classモジュールのバージョン文字列。
- 
メソッドのサマリー修飾子と型メソッド説明intcompareTo(ModuleDescriptor that) このモジュール記述子を別のモジュール記述子と比較します。booleanこのモジュール記述子が指定されたオブジェクトと等しいかどうかをテストします。exports()エクスポートされたパッケージを表すExportsオブジェクトのセットを返します。inthashCode()このモジュール記述子のハッシュ・コードを計算します。boolean自動モジュールの場合はtrueを返します。booleanisOpen()オープン・モジュールの場合はtrueを返します。モジュール・メイン・クラスを返します。モジュール修飾子のセットを返します。name()モジュール名を返します。static ModuleDescriptor.BuildernewAutomaticModule(String name) ビルダーをインスタンス化して、自動モジュール用のモジュール記述子を作成します。static ModuleDescriptor.Builderビルダーをインスタンス化して、normalモジュールのモジュール記述子を作成します。static ModuleDescriptor.BuildernewModule(String name, Set<ModuleDescriptor.Modifier> ms) ビルダーをインスタンス化してモジュール記述子を構築します。static ModuleDescriptor.BuildernewOpenModule(String name) ビルダーをインスタンス化して、オープン・モジュール用のモジュール記述子を作成します。opens()開いているパッケージを表すOpensオブジェクトのセットを返します。packages()モジュール内のパッケージのセットを返します。provides()モジュールが提供するサービスを表すProvidesオブジェクトのセットを返します。おそらく解析不能なバージョンのモジュールを含む文字列を返します。static ModuleDescriptorread(InputStream in) モジュール記述子のバイナリ形式を入力ストリームからモジュール記述子として読み込みます。static ModuleDescriptorread(InputStream in, Supplier<Set<String>> packageFinder) モジュール記述子のバイナリ形式を入力ストリームからモジュール記述子として読み込みます。static ModuleDescriptorread(ByteBuffer bb) モジュール記述子のバイナリ形式をバイト・バッファからモジュール記述子として読み込みます。static ModuleDescriptorread(ByteBuffer bb, Supplier<Set<String>> packageFinder) モジュール記述子のバイナリ形式をバイト・バッファからモジュール記述子として読み込みます。requires()モジュールの依存関係を表すRequiresオブジェクトのセットを返します。モジュール名と存在する場合はそのバージョンを含む文字列を返します。toString()モジュールを説明する文字列を返します。uses()サービス依存のセットを返します。version()モジュールのバージョンを返します。
- 
メソッドの詳細- 
namepublic String name()モジュール名を返します。 - 戻り値:
- モジュール名
 
- 
modifierspublic Set<ModuleDescriptor.Modifier> modifiers()モジュール修飾子のセットを返します。 - 戻り値:
- おそらく空の変更不可能な修飾子のセット
 
- 
isOpenpublic boolean isOpen()- 戻り値:
- trueオープン・モジュールの場合
 
- 
isAutomaticpublic boolean isAutomatic()- 戻り値:
- trueこれが自動モジュールの場合
 
- 
requirespublic Set<ModuleDescriptor.Requires> requires()モジュールの依存関係を表す Requiresオブジェクトのセットを返します。セットには、このモジュールの名前が" java.base"でない場合の"java.base"への依存が含まれています。 このモジュールが自動モジュールである場合、"java.base"以外のモジュールには依存しません。- 戻り値:
- ModuleDescriptor.Requiresオブジェクトの、おそらく空の変更不可能なセット
 
- 
exportspublic Set<ModuleDescriptor.Exports> exports()エクスポートされたパッケージを表す Exportsオブジェクトのセットを返します。このモジュールが自動モジュールの場合、一連のエクスポートは空です。 - 戻り値:
- エクスポートされたパッケージのおそらく空の変更不可能なセット
 
- 
openspublic Set<ModuleDescriptor.Opens> opens()開いているパッケージを表す Opensオブジェクトのセットを返します。このモジュールがオープン・モジュールまたは自動モジュールの場合、オープン・パッケージのセットは空です。 - 戻り値:
- 可能な限り空の変更不可能なオープン・パッケージのセット
 
- 
usesサービス依存のセットを返します。 このモジュールが自動モジュールの場合、サービス依存のセットは空です。 - 戻り値:
- 使用されているサービス型の完全修飾クラス名の、おそらく空の変更不可能なセット
 
- 
providespublic Set<ModuleDescriptor.Provides> provides()モジュールが提供するサービスを表す Providesオブジェクトのセットを返します。- 戻り値:
- このモジュールが提供するサービスの、おそらく空の変更不可能なセット
 
- 
versionpublic Optional<ModuleDescriptor.Version> version()モジュールのバージョンを返します。 - 戻り値:
- このモジュールのバージョン、またはモジュールにバージョンがないか、バージョンがunparseableの場合は空のOptional
 
- 
rawVersionおそらく解析不能なバージョンのモジュールを含む文字列を返します。 - 戻り値:
- モジュールのバージョンを含む文字列、またはモジュールにバージョンがない場合は空のOptional
- 関連項目:
 
- 
toNameAndVersionpublic String toNameAndVersion()モジュール名と存在する場合はそのバージョンを含む文字列を返します。 - 戻り値:
- モジュール名と存在する場合はそのバージョンを含む文字列
 
- 
mainClassモジュール・メイン・クラスを返します。 - 戻り値:
- モジュール・メイン・クラスの完全修飾クラス名
 
- 
packagesモジュール内のパッケージのセットを返します。パッケージのセットには、すべてのエクスポートされたパッケージとオープンされたパッケージ、サービス・プロバイダのパッケージ、およびメイン・クラスのパッケージが含まれます。 - 戻り値:
- おそらく空の、モジュール内のパッケージの変更不可能なセット
 
- 
compareTopublic int compareTo(ModuleDescriptor that) このモジュール記述子を別のモジュール記述子と比較します。2つの ModuleDescriptorオブジェクトは、モジュール名を辞書的に比較することによって比較されます。 モジュール名が等しい場合、モジュールのバージョンが比較されます。 モジュールのバージョンを比較するとき、バージョンを持つモジュール記述子は、バージョンを持たないモジュール記述子を継承すると見なされます。 両方のバージョンがunparseableの場合、「生バージョンの文字列」は辞書順に比較されます。 モジュール名が等しく、バージョンが(または両方に存在しない)と等しい場合、修飾子のセットが比較されます。 修飾子のセットは、各セットについて計算された「バイナリ値」を比較することによって比較されます。 修飾子がセットに存在する場合、その序数の位置にあるビットは、バイナリ値では1、それ以外の場合は0です。 2組の修飾語が同じ場合、equalsと一貫性のある方法で、モジュール記述子の他のコンポーネントが比較されます。- 定義:
- インタフェースComparable<ModuleDescriptor>内のcompareTo
- パラメータ:
- that- 比較するモジュール記述子
- 戻り値:
- このモジュール記述子が指定されたモジュール記述子よりも小さい、等しい、または大きい場合は、負の整数、ゼロまたは正の整数。
 
- 
equalspublic boolean equals(Object ob) このモジュール記述子が指定されたオブジェクトと等しいかどうかをテストします。指定されたオブジェクトが ModuleDescriptorでない場合、このメソッドはfalseを返します。 対応するコンポーネントのそれぞれが等しい場合、2つのモジュール記述子は等しい。このメソッドは Object.equalsメソッドの汎用規約を満たします。
- 
hashCodepublic int hashCode()このモジュール記述子のハッシュ・コードを計算します。ハッシュ・コードは、モジュール記述子のコンポーネントに基づいており、 Object.hashCodeメソッドの一般規約を満たしています。
- 
toStringpublic String toString()モジュールを説明する文字列を返します。 
- 
newModulepublic static ModuleDescriptor.Builder newModule(String name, Set<ModuleDescriptor.Modifier> ms) ビルダーをインスタンス化してモジュール記述子を構築します。- パラメータ:
- name- モジュール名
- ms- モジュール修飾子のセット
- 戻り値:
- 新しいビルダー
- 例外:
- IllegalArgumentException- モジュール名が- nullであるか、正式なモジュール名でないか、修飾子のセットに他の修飾子を含む- AUTOMATICが含まれている場合
 
- 
newModulepublic static ModuleDescriptor.Builder newModule(String name) - パラメータ:
- name- モジュール名
- 戻り値:
- 新しいビルダー
- 例外:
- IllegalArgumentException- モジュール名が- nullであるか、正当なモジュール名ではない
 
- 
newOpenModulepublic static ModuleDescriptor.Builder newOpenModule(String name) ビルダーをインスタンス化して、オープン・モジュール用のモジュール記述子を作成します。 このメソッドは、OPEN修飾子を指定してnewModuleを呼び出すのと同じです。オープン・モジュールのビルダーを使用して、開いているパッケージを宣言することはできません。 - パラメータ:
- name- モジュール名
- 戻り値:
- オープン・モジュールを構築する新しいビルダー
- 例外:
- IllegalArgumentException- モジュール名が- nullであるか、正当なモジュール名ではない
 
- 
newAutomaticModulepublic static ModuleDescriptor.Builder newAutomaticModule(String name) ビルダーをインスタンス化して、自動モジュール用のモジュール記述子を作成します。 このメソッドは、AUTOMATIC修飾子を指定してnewModuleを呼び出すのと同じです。自動モジュール用のビルダーを使用して、モジュールまたはサービスの依存関係を宣言することはできません。 また、エクスポートされたパッケージまたは開いているパッケージを宣言するために使用することはできません。 - パラメータ:
- name- モジュール名
- 戻り値:
- 自動モジュールを構築する新しいビルダー
- 例外:
- IllegalArgumentException- モジュール名が- nullであるか、正当なモジュール名ではない
- 関連項目:
 
- 
readpublic static ModuleDescriptor read(InputStream in, Supplier<Set<String>> packageFinder) throws IOException モジュール記述子のバイナリ形式を入力ストリームからモジュール記述子として読み込みます。入力ストリームでエンコードされた記述子がモジュール内のパッケージのセットを示さない場合は、 packageFinderが呼び出されます。packageFinderが返すパッケージのセットには、モジュールがエクスポートして開くすべてのパッケージ、モジュールが提供するサービス実装のパッケージ、およびメイン・クラス(モジュールにメイン・クラスがある場合)のパッケージが含まれている必要があります。packageFinderがUncheckedIOExceptionをスローすると、IOException原因が再スローされます。モジュール記述子の後にバイトがある場合、これらのバイトが読み込まれたか、無視されたか、または InvalidModuleDescriptorExceptionとして報告されるかは実装固有です。 このメソッドがInvalidModuleDescriptorExceptionまたはIOExceptionで失敗した場合、すべてではないバイトの一部が入力ストリームから読み込まれた後にこのメソッドが実行される可能性があります。 例外が発生した場合、ストリームをすぐに閉じて破棄することを強くお勧めします。- APIのノート:
- packageFinderパラメータは、記述子自体にパッケージのセットを記録しないレガシー・モジュール・アーティファクト形式からモジュール記述子を読み取るときに使用します。
- パラメータ:
- in- 入力ストリーム
- packageFinder- パッケージのセットを作成できるサプライヤ
- 戻り値:
- モジュール記述子
- 例外:
- InvalidModuleDescriptorException- 無効なモジュール記述子が検出された場合、または- packageFinderによって返されたパッケージのセットに、モジュール記述子から取得されたすべてのパッケージが含まれていない場合
- IOException- I/Oエラーが入力ストリームから読み取られるか、- UncheckedIOExceptionがパッケージ・ファインダによってスローされた場合
 
- 
readpublic static ModuleDescriptor read(InputStream in) throws IOException モジュール記述子のバイナリ形式を入力ストリームからモジュール記述子として読み込みます。 このメソッドは、2-argreadメソッドで指定されたとおりに機能します。ただし、ストリームから読み取られたモジュール記述子がパッケージのセットを示していない場合、パッケージ・ファインダを使用して追加のパッケージを検索することはありません。- パラメータ:
- in- 入力ストリーム
- 戻り値:
- モジュール記述子
- 例外:
- InvalidModuleDescriptorException- 無効なモジュール記述子が検出された場合
- IOException- 入力ストリームからの読み込みでI/Oエラーが発生した場合
 
- 
readpublic static ModuleDescriptor read(ByteBuffer bb, Supplier<Set<String>> packageFinder) モジュール記述子のバイナリ形式をバイト・バッファからモジュール記述子として読み込みます。バイト・バッファでエンコードされた記述子がモジュール内のパッケージのセットを示さない場合は、 packageFinderが呼び出されます。packageFinderが返すパッケージのセットには、モジュールがエクスポートして開くすべてのパッケージ、モジュールが提供するサービス実装のパッケージ、およびメイン・クラス(モジュールにメイン・クラスがある場合)のパッケージが含まれている必要があります。packageFinderがUncheckedIOExceptionをスローすると、IOException原因が再スローされます。モジュール記述子は、索引 pからバッファから読み取られます。このメソッドが呼び出されると、pはバッファpositionになります。 戻り時に、バッファ位置はp + nに等しくなります。ここで、nはバッファから読み取られたバイト数です。モジュール記述子の後にバイトがある場合、これらのバイトが読み込まれたか、無視されたか、または InvalidModuleDescriptorExceptionとして報告されるかは実装固有です。 このメソッドがInvalidModuleDescriptorExceptionで失敗した場合、すべてではないバイトの一部が読み込まれた後にこのメソッドが実行される可能性があります。- APIのノート:
- packageFinderパラメータは、記述子自体にパッケージのセットを記録しないレガシー・モジュール・アーティファクト形式からモジュール記述子を読み取るときに使用します。
- パラメータ:
- bb- バイト・バッファ
- packageFinder- パッケージのセットを作成できるサプライヤ
- 戻り値:
- モジュール記述子
- 例外:
- InvalidModuleDescriptorException- 無効なモジュール記述子が検出された場合、または- packageFinderによって返されたパッケージのセットに、モジュール記述子から取得されたすべてのパッケージが含まれていない場合
 
- 
readpublic static ModuleDescriptor read(ByteBuffer bb) モジュール記述子のバイナリ形式をバイト・バッファからモジュール記述子として読み込みます。 このメソッドは、2-argreadメソッドで指定されたとおりに機能します。ただし、バッファにエンコードされたモジュール記述子がパッケージのセットを示していない場合、パッケージ・ファインダを使用して追加のパッケージを検索することはありません。- パラメータ:
- bb- バイト・バッファ
- 戻り値:
- モジュール記述子
- 例外:
- InvalidModuleDescriptorException- 無効なモジュール記述子が検出された場合
 
 
-