- 直系の既知のサブクラス:
SecureClassLoader
public abstract class ClassLoader extends Object
ClassLoaderクラスは抽象クラスです。 クラスのバイナリ名を指定すると、クラス・ローダーはクラスの定義を構成するデータを見つけるか生成します。 一般的な方法としては、名前をファイル名に変換して、ファイル・システムからその名前の「クラス・ファイル」を読み込みます。
すべてのClassオブジェクトには、それを定義したClassLoaderへのreferenceが含まれています。
配列クラスのClassオブジェクトは、クラス・ローダーによっては作成されず、Java Runtimeの要求に応じて自動的に作成されます。 配列クラスのクラス・ローダー(Class.getClassLoader()から返される)は、その要素の型のクラス・ローダーと同じになります。要素の型がプリミティブ型の場合、配列クラスはクラス・ローダーを持ちません。
アプリケーションは、Java仮想マシンが動的にクラスをロードするように拡張するために、ClassLoaderのサブクラスを実装します。
クラス・ローダーは一般的に、セキュリティ・マネージャがセキュリティ・ドメインを示すために使われます。
クラスをロードすることに加えて、クラス・ローダーはリソースの特定も担当します。 リソースとは、'/'という抽象パス名で識別されるデータです。 リソースは通常、アプリケーションまたはライブラリにパッケージ化されているため、アプリケーションまたはライブラリ内のコードでリソースを見つけることができます。 場合によっては、リソースが他のライブラリに配置されるように含まれています。
ClassLoaderクラスは、委譲モデルを使ってクラスとリソースを探します。 ClassLoaderの各インスタンスは、関連する親クラス・ローダーを持ちます。 ClassLoaderインスタンスは、クラスまたはリソースの検索をリクエストされると、そのクラスまたはリソース自体の検索を試みる前に、そのクラスまたはリソースの検索を親クラス・ローダーに委譲します。
クラスの同時ロードをサポートするクラス・ローダーは、「並列対応」クラス・ローダーと呼ばれ、ClassLoader.registerAsParallelCapableメソッドを呼び出すことによってクラス初期化時に登録する必要があります。 ClassLoaderクラスはデフォルトで並行可能として登録されます。 ただしそのサブクラスについては、並行可能な場合には自身を登録する必要があります。 委譲モデルが厳密に階層的でない環境では、クラス・ローダーは並列対応が可能でなければなりません。そうしないと、クラス・ローディング・プロセス(loadClassメソッドを参照してください)中にローダー・ロックが保持されるため、クラス・ローディングによってデッドロックが発生する可能性があります。
ランタイム・ビルト・イン・クラス・ローダー
Javaランタイムには、次の組み込みクラス・ローダーがあります:ブートストラップ・クラス・ローダー。 仮想マシンの組み込みクラス・ローダーで、通常は
nullで表され、親はありません。「プラットフォーム・クラス・ローダー」。 すべての「プラットフォーム・クラス」は、
ClassLoaderインスタンスの親として使用できるプラットフォーム・クラス・ローダーに表示されます。 プラットフォーム・クラスには、Java SEプラットフォームAPI、その実装クラス、およびプラットフォーム・クラス・ローダーまたはその祖先によって定義されたJDK固有の実行時クラスが含まれます。プラットフォーム・クラス・ローダーに定義されたモジュールのアップグレード/オーバーライドを可能にするために、アップグレードされたモジュールが定義されたモジュールをプラットフォーム・クラス・ローダーとその祖先以外のクラス・ローダーに読み込む場合、プラットフォーム・クラス・ローダーは他のクラス・ローダーに委譲する必要があります。アプリケーション・クラス・ローダーなどがあります。 言い換えれば、プラットフォーム・クラス・ローダーとその祖先以外のクラス・ローダーに定義された名前付きモジュールのクラスは、プラットフォーム・クラス・ローダーに可視である可能性があります。
「システム・クラス・ローダー」。 「アプリケーション・クラス・ローダー」とも呼ばれ、プラットフォーム・クラス・ローダーとは異なります。 システム・クラス・ローダーは、通常、アプリケーション・クラス・パス、モジュール・パス、およびJDK固有のツールでクラスを定義するために使用されます。 プラットフォーム・クラス・ローダーは、すべてのプラットフォーム・クラスが可視であるシステム・クラス・ローダーの親または祖先です。
通常、Java仮想マシンは、プラットフォームに依存しない方法でローカル・ファイル・システムからクラスをロードします。 ただし、ファイルから作成できないクラスもあります。このようなクラスは、ネットワークなどのほかのソースから作成したり、アプリケーションが構築したりします。 メソッドdefineClassは、バイトの配列をクラスClassのインスタンスに変換します。 この新たに定義されたクラスのインスタンスは、Class.newInstanceを使用して作成できます。
クラス・ローダーで作成したオブジェクトのメソッドとコンストラクタは、ほかのクラスを参照できます。 参照されるclass(es)を決定するために、Java仮想マシンは、クラスを最初に作成したクラス・ローダーのloadClassメソッドを呼び出します。
たとえば、アプリケーションはネットワーク・クラス・ローダーを作成して、サーバーからクラス・ファイルをダウンロードできます。 コードは次のようになります。
ClassLoader loader = new NetworkClassLoader(host, port);
Object main = loader.loadClass("Main", true).newInstance();
. . .
ネットワーク・クラス・ローダー・サブクラスは、ネットワークからクラスをロードするために、メソッドfindClassとloadClassDataを定義する必要があります。 クラスを構成するバイトをダウンロードしたら、メソッドdefineClassを使用してクラス・インスタンスを作成する必要があります。 実装の例を次に示します。
class NetworkClassLoader extends ClassLoader {
String host;
int port;
public Class findClass(String name) {
byte[] b = loadClassData(name);
return defineClass(name, b, 0, b.length);
}
private byte[] loadClassData(String name) {
// load the class data from the connection
. . .
}
}
バイナリ名
ClassLoaderのメソッドのStringパラメータとして指定するクラス名はすべて、『Java™言語仕様』で規定されたバイナリ名である必要があります。
次に、有効なクラス名の例を示します。
"java.lang.String" "javax.swing.JSpinner$DefaultEditor" "java.security.KeyStore$Builder$FileBuilder$1" "java.net.URLClassLoader$3$1"
ClassLoaderのメソッドへのStringパラメータとして指定されたパッケージ名は、空の文字列(名前のないパッケージを示す)または「Java™言語仕様」で定義された完全修飾名でなければなりません。
- Java言語仕様を参照してください:
-
6.7 完全修飾名
「13.1バイナリの形式」 - 導入されたバージョン:
- 1.0
- 関連項目:
resolveClass(Class)
-
コンストラクタのサマリー
コンストラクタ 修飾子 コンストラクタ 説明 protectedClassLoader()getSystemClassLoader()メソッドによって返されたClassLoaderを親クラス・ローダーとして使用して、新しいクラス・ローダーを作成します。protectedClassLoader(ClassLoader parent)指定された親クラス・ローダーを使って、委譲のために新しいクラス・ローダーを作成します。protectedClassLoader(String name, ClassLoader parent)指定された名前の新しいクラス・ローダーを作成し、指定された親クラス・ローダーを委譲のために使用します。 -
メソッドのサマリー
修飾子と型 メソッド 説明 voidclearAssertionStatus()このクラス・ローダーのデフォルトのアサーション・ステータスをfalseに設定し、クラス・ローダーに関連付けられたパッケージ・デフォルトまたはクラスのアサーション・ステータス設定をすべて破棄します。protected Class<?>defineClass(byte[] b, int off, int len)非推奨。defineClass(String, byte[], int, int)に置き換えられています。protected Class<?>defineClass(String name, byte[] b, int off, int len)バイトの配列をClassクラスのインスタンスに変換します。protected Class<?>defineClass(String name, byte[] b, int off, int len, ProtectionDomain protectionDomain)指定されたProtectionDomainを使用して、バイトの配列をクラスClassのインスタンスに変換します。protected Class<?>defineClass(String name, ByteBuffer b, ProtectionDomain protectionDomain)指定されたProtectionDomainを使用して、ByteBufferをクラスClassのインスタンスに変換します。protected PackagedefinePackage(String name, String specTitle, String specVersion, String specVendor, String implTitle, String implVersion, String implVendor, URL sealBase)このClassLoaderにnameでパッケージを定義します。protected Class<?>findClass(String name)指定されたバイナリ名を持つクラスを探します。protected Class<?>findClass(String moduleName, String name)このクラス・ローダーに定義されたモジュール内の指定された「バイナリ名」を持つクラスを検索します。protected StringfindLibrary(String libname)ネイティブ・ライブラリの絶対パス名を返します。protected Class<?>findLoadedClass(String name)protected URLfindResource(String name)指定された名前を持つリソースを検索します。protected URLfindResource(String moduleName, String name)このクラス・ローダーに定義されたモジュール内のリソースへのURLを返します。protected Enumeration<URL>findResources(String name)指定された名前を持つすべてのリソースを表すURLオブジェクトの列挙型を返します。protected Class<?>findSystemClass(String name)指定されたバイナリ名を持つクラスを探して、必要に応じてロードします。protected ObjectgetClassLoadingLock(String className)クラス・ロード操作用のロック・オブジェクトを返します。PackagegetDefinedPackage(String name)このクラス・ローダーによって定義されたnameのPackageを返します。Package[]getDefinedPackages()このクラス・ローダーによって定義されたすべてのPackageを返します。StringgetName()このクラス・ローダーの名前が返されない場合は、このクラス・ローダーの名前またはnullを返します。protected PackagegetPackage(String name)非推奨。複数のクラス・ローダーが互いに委譲して同じパッケージ名を持つクラスを定義し、そのようなローダーの1つがgetPackageのルックアップ動作に依存して親ローダーからPackageを返す場合、Packageによって公開されるプロパティは残りのプログラムで期待どおりにならない場合があります。protected Package[]getPackages()このクラス・ローダーとその祖先によって定義されたすべてのPackageを返します。ClassLoadergetParent()委譲のための親クラス・ローダーを返します。static ClassLoadergetPlatformClassLoader()プラットフォーム・クラス・ローダーを返します。URLgetResource(String name)指定された名前を持つリソースを検索します。InputStreamgetResourceAsStream(String name)指定されたリソースを読み込む入力ストリームを返します。Enumeration<URL>getResources(String name)指定された名前を持つすべてのリソースを検索します。static ClassLoadergetSystemClassLoader()システム・クラス・ローダーを返します。static URLgetSystemResource(String name)クラスをロードするために使用される検索パスから、指定された名前のリソースを探します。static InputStreamgetSystemResourceAsStream(String name)クラスをロードするのに使用される検索パスから、指定された名前のリソースを、読込み用にオープンします。static Enumeration<URL>getSystemResources(String name)クラスをロードするために使用される検索パスから、指定された名前のすべてのリソースを探します。ModulegetUnnamedModule()このクラス・ローダーの名前のないModuleを返します。booleanisRegisteredAsParallelCapable()このクラス・ローダーが「並列対応」、それ以外の場合はfalseとして登録されている場合はtrueを返します。Class<?>loadClass(String name)指定されたバイナリ名を持つクラスをロードします。protected Class<?>loadClass(String name, boolean resolve)指定されたバイナリ名を持つクラスをロードします。protected static booleanregisterAsParallelCapable()呼び出し元を「並列対応」として登録します。protected voidresolveClass(クラス<?> c)指定されたクラスをリンクします。Stream<URL>resources(String name)要素が指定された名前を持つすべてのリソースのURLであるストリームを返します。voidsetClassAssertionStatus(String className, boolean enabled)このクラス・ローダーの指定されたトップレベル・クラスおよびそこに含まれるネストされたクラス内に対して、目的のアサーション・ステータスを設定します。voidsetDefaultAssertionStatus(boolean enabled)このクラス・ローダーのデフォルトのアサーション・ステータスを設定します。voidsetPackageAssertionStatus(String packageName, boolean enabled)指定されたパッケージ・デフォルトのアサーション・ステータスを設定します。protected voidsetSigners(Class<?> c, Object[] signers)クラスの署名者を設定します。
-
コンストラクタの詳細
-
ClassLoader
protected ClassLoader(String name, ClassLoader parent)指定された名前の新しいクラス・ローダーを作成し、指定された親クラス・ローダーを委譲のために使用します。- APIの注:
- 親が
null(ブートストラップ・クラス・ローダー用)として指定されている場合、すべてのプラットフォーム・クラスが可視であるという保証はありません。 - パラメータ:
name- クラス・ローダー名;名前が付けられていない場合はnullparent- 親クラス・ローダー- 例外:
IllegalArgumentException- 指定された名前が空の場合。SecurityException- セキュリティ・マネージャが存在し、そのSecurityManager.checkCreateClassLoader()メソッドが新しいクラス・ローダーの作成を許可しない場合。- 導入されたバージョン:
- 9
-
ClassLoader
protected ClassLoader(ClassLoader parent)指定された親クラス・ローダーを使って、委譲のために新しいクラス・ローダーを作成します。セキュリティ・マネージャが存在する場合、その
checkCreateClassLoaderメソッドが呼び出されます。 これはセキュリティ例外となる場合があります。- APIの注:
- 親が
null(ブートストラップ・クラス・ローダー用)として指定されている場合、すべてのプラットフォーム・クラスが可視であるという保証はありません。 - パラメータ:
parent- 親クラス・ローダー- 例外:
SecurityException- セキュリティ・マネージャが存在し、そのcheckCreateClassLoaderメソッドが新しいクラス・ローダーの作成を許可しない場合- 導入されたバージョン:
- 1.2
-
ClassLoader
protected ClassLoader()getSystemClassLoader()メソッドによって返されたClassLoaderを親クラス・ローダーとして使用して、新しいクラス・ローダーを作成します。セキュリティ・マネージャが存在する場合、その
checkCreateClassLoaderメソッドが呼び出されます。 これはセキュリティ例外となる場合があります。- 例外:
SecurityException- セキュリティ・マネージャが存在し、そのcheckCreateClassLoaderメソッドが新しいクラス・ローダーの作成を許可しない場合
-
-
メソッドの詳細
-
getName
public String getName()このクラス・ローダーの名前が返されない場合は、このクラス・ローダーの名前またはnullを返します。- APIの注:
- このメソッドは、互換性のために最終的なものではありません。 このメソッドがオーバーライドされている場合、このメソッドは、このクラス・ローダーがインスタンス化されたときに指定されたものと同じ名前を返す必要があります。
- 戻り値:
- このクラス・ローダーの名前。このクラス・ローダーが指定されていない場合は
null。 - 導入されたバージョン:
- 9
-
loadClass
public Class<?> loadClass(String name) throws ClassNotFoundException指定されたバイナリ名を持つクラスをロードします。 このメソッドでのクラスの検索方法は、loadClass(String, boolean)メソッドの場合と同じです。 Java仮想マシンがこのメソッドを呼び出して、クラス参照を解決します。 このメソッドを呼び出すことは、loadClass(name, false)を呼び出すことと同じです。- パラメータ:
name- クラスのバイナリ名- 戻り値:
- 結果として得られる
Classオブジェクト - 例外:
ClassNotFoundException- クラスが見つからなかった場合
-
loadClass
protected Class<?> loadClass(String name, boolean resolve) throws ClassNotFoundException指定されたバイナリ名を持つクラスをロードします。 このメソッドのデフォルト実装では、次の順序でクラスを検索します。クラスがすでにロードされていないかチェックするために
findLoadedClass(String)を呼び出す。親クラス・ローダーで
loadClassメソッドを呼び出します。 親がnullの場合、代わりに仮想マシンに組み込まれたクラス・ローダーが使用されます。findClass(String)メソッドを呼び出してクラスを探す。
上記のステップでクラスが見つかった場合、
resolveフラグがtrueのときには、このメソッドは見つかったClassオブジェクトに対してresolveClass(Class)メソッドを呼び出します。ClassLoaderのサブクラスでは、このメソッドではなくfindClass(String)をオーバーライドすることをお薦めします。オーバーライドされていない限り、このメソッドはクラス・ロード処理全体の中で
getClassLoadingLockメソッドの結果と同期します。- パラメータ:
name- クラスのバイナリ名resolve-trueの場合は、クラスを解決する- 戻り値:
- 結果として得られる
Classオブジェクト - 例外:
ClassNotFoundException- クラスが見つからなかった場合
-
getClassLoadingLock
クラス・ロード操作用のロック・オブジェクトを返します。 下位互換性のため、このメソッドのデフォルト実装は次のように動作します。 このClassLoaderオブジェクトが並行可能として登録されている場合、このメソッドは、指定されたクラス名に関連付けられた専用オブジェクトを返します。 それ以外の場合、メソッドはこのClassLoaderオブジェクトを返します。- パラメータ:
className- ロードするクラスの名前- 戻り値:
- クラス・ロード処理用のロック
- 例外:
NullPointerException- 並行可能として登録されていて、classNameがnullの場合- 導入されたバージョン:
- 1.7
- 関連項目:
loadClass(String, boolean)
-
findClass
protected Class<?> findClass(String name) throws ClassNotFoundException指定されたバイナリ名を持つクラスを探します。 このメソッドは、クラスをロードするための委譲モデルに続くクラス・ローダー実装によってオーバーライドされ、リクエストされたクラスの親クラス・ローダーをチェックした後にloadClassメソッドによって呼び出されます。- 実装要件:
- デフォルトの実装では、
ClassNotFoundExceptionがスローされます。 - パラメータ:
name- クラスのバイナリ名- 戻り値:
- 結果として得られる
Classオブジェクト - 例外:
ClassNotFoundException- クラスが見つからなかった場合- 導入されたバージョン:
- 1.2
-
findClass
このクラス・ローダーに定義されたモジュール内の指定された「バイナリ名」を持つクラスを検索します。 モジュールからのロードをサポートするクラス・ローダー実装は、このメソッドをオーバーライドする必要があります。- APIの注:
- このメソッドは、クラスが見つからない場合は
ClassNotFoundExceptionをスローするのではなく、nullを返します。 - 実装要件:
moduleNameがnullのとき、findClass(String)を呼び出すことによって、デフォルトの実装がクラスを見つけようとします。 そうでなければ、nullを返します。- パラメータ:
moduleName- モジュール名。またはnullを使用して、このクラス・ローダーの「名前のないモジュール」内のクラスを見つけますname- クラスのバイナリ名- 戻り値:
- 結果の
Classオブジェクト、またはクラスが見つからなかった場合はnullオブジェクト。 - 導入されたバージョン:
- 9
-
defineClass
@Deprecated(since="1.1")protected final Class<?> defineClass(byte[] b, int off, int len) throws ClassFormatError非推奨。defineClass(String, byte[], int, int)に置き換えられています。バイトの配列をClassクラスのインスタンスに変換します。 最初にClassを解決してからでなければ、それを使用することはできません。 このメソッドは非推奨です。バイナリ名を最初の引数として取るバージョンの方が安全であるため、そのバージョンを使用するようにしてください。- パラメータ:
b- クラス・データを構成するバイト。offからoff+len-1までの位置にあるbyteは、『Java™仮想マシン仕様』で定義される有効なクラス・ファイルの形式を持つ。off- クラス・データのb内での開始オフセットlen- クラス・データの長さ- 戻り値:
- 指定されたクラス・データから作成された
Classオブジェクト - 例外:
ClassFormatError- データが有効なクラスを含まなかった場合IndexOutOfBoundsException-offまたはlenが負の場合、またはoff+lenがb.lengthより大きい場合SecurityException- このクラスとは異なる一連の証明書で署名されたクラスを含むパッケージにこのクラスを追加しようとした場合、または「java.」で始まる完全指定名を持つパッケージ内でクラスを定義しようとした場合。- 関連項目:
loadClass(String, boolean),resolveClass(Class)
-
defineClass
protected final Class<?> defineClass(String name, byte[] b, int off, int len) throws ClassFormatErrorバイトの配列をClassクラスのインスタンスに変換します。 最初にClassを解決してからでなければ、それを使用することはできません。このメソッドは、新しく定義されたクラスにデフォルトの
ProtectionDomainを割り当てます。ProtectionDomainには、Policy.getPolicy().getPermissions(new CodeSource(null, null))が呼び出されたときに返される同じセットのアクセス権が効果的に与えられます。 デフォルトの保護ドメインは、defineClassの最初の呼び出しで作成され、後続の呼び出しで再使用されます。特定の
ProtectionDomainをクラスに割り当てるには、引数の1つとしてProtectionDomainを取るdefineClassメソッドを使用します。このメソッドは、
Class(そのようなパッケージがこのクラス・ローダーでまだ定義されていない場合)のパッケージに対応するこのクラス・ローダー内のパッケージを定義します。 定義されたパッケージの名前は、バイト配列bで指定されたクラスの「バイナリ名」から派生します。 定義されたパッケージのその他のプロパティは、Packageで指定されたものです。- パラメータ:
name- クラスの予想されるバイナリ名。不明な場合はnullb- クラス・データを構成するバイト。offからoff+len-1までの位置にあるbyteは、『Java™仮想マシン仕様』で定義される有効なクラス・ファイルの形式を持つ。off- クラス・データのb内での開始オフセットlen- クラス・データの長さ- 戻り値:
- 指定されたクラス・データから作成された
Classオブジェクト。 - 例外:
ClassFormatError- データが有効なクラスを含まなかった場合IndexOutOfBoundsException-offまたはlenが負の場合、またはoff+lenがb.lengthより大きい場合SecurityException- このクラス(未署名)とは異なる証明書セットを使って署名されたクラスを含むパッケージに、このクラスを追加しようとした場合、またはnameが「java.」で始まる場合。- 導入されたバージョン:
- 1.1
- 関連項目:
loadClass(String, boolean),resolveClass(Class),CodeSource,SecureClassLoader
-
defineClass
protected final Class<?> defineClass(String name, byte[] b, int off, int len, ProtectionDomain protectionDomain) throws ClassFormatError指定されたProtectionDomainを使用して、バイトの配列をクラスClassのインスタンスに変換します。指定された
ProtectionDomainがnullの場合、defineClass(String, byte[], int, int)のドキュメントで指定されているように、デフォルトの保護ドメインがクラスに割り当てられます。 最初にクラスを解決してからでなければ、クラスを使用することはできません。パッケージで定義される最初のクラスにより、そのパッケージ内で続いて定義されたすべてのクラスに必要な、証明書の正確なセットが決まります。 クラスの証明書セットは、クラスの
ProtectionDomain内のCodeSourceから取得されます。 そのパッケージに追加されたクラスには同一の証明書のセットが含まれている必要があり、含まれていない場合はSecurityExceptionがスローされます。nameがnullの場合、この判別は実行されません。 必ず、定義するクラスのバイナリ名をバイトとともに渡すようにしてください。 このようにして渡すと、定義するクラスは実際に考えたとおりのクラスになります。指定された
nameが"java."で始まる場合は、「プラットフォーム・クラス・ローダー」またはその祖先でのみ定義できます。それ以外の場合はSecurityExceptionがスローされます。nameがnullでない場合は、バイト配列bで指定されたクラスの「バイナリ名」と等しくなければなりません。それ以外の場合はNoClassDefFoundErrorがスローされます。このメソッドは、
Class(そのようなパッケージがこのクラス・ローダーでまだ定義されていない場合)のパッケージに対応するこのクラス・ローダー内のパッケージを定義します。 定義されたパッケージの名前は、バイト配列bで指定されたクラスの「バイナリ名」から派生します。 定義されたパッケージのその他のプロパティは、Packageで指定されたものです。- パラメータ:
name- クラスの予想されるバイナリ名。不明な場合はnullb- クラス・データを構成するバイト。offからoff+len-1までの位置にあるbyteは、『Java™仮想マシン仕様』で定義される有効なクラス・ファイルの形式を持つ。off- クラス・データのb内での開始オフセットlen- クラス・データの長さprotectionDomain- クラスのProtectionDomain- 戻り値:
- データから作成された
ClassオブジェクトとProtectionDomain。 - 例外:
ClassFormatError- データが有効なクラスを含まなかった場合NoClassDefFoundError-nameがnullでなく、bで指定されたクラスの「バイナリ名」と等しくない場合IndexOutOfBoundsException-offまたはlenが負の場合、またはoff+lenがb.lengthより大きい場合SecurityException- このクラスを、このクラスとは異なる証明書セットで署名されたクラスを含むパッケージに追加しようとした場合、またはnameが"java."で始まり、このクラス・ローダーがプラットフォーム・クラス・ローダーまたはその祖先でない場合。
-
defineClass
protected final Class<?> defineClass(String name, ByteBuffer b, ProtectionDomain protectionDomain) throws ClassFormatError指定されたProtectionDomainを使用して、ByteBufferをクラスClassのインスタンスに変換します。 指定されたProtectionDomainがnullの場合、defineClass(String, byte[], int, int)のドキュメントで指定されているように、デフォルトの保護ドメインがクラスに割り当てられます。 最初にクラスを解決してからでなければ、クラスを使用することはできません。パッケージの証明書セット、クラス名の制限、およびクラスの定義済みパッケージを決定するパッケージで定義されたファースト・クラスに関するルールは、
defineClass(String, byte[], int, int, ProtectionDomain)のドキュメントで指定されているルールと同じです。このメソッドをcl
.defineClass(name,bBuffer,pd)の形式で呼び出すと、次の文とまったく同じ結果が得られます...
byte[] temp = new byte[bBuffer.remaining()];
bBuffer.get(temp);
returncl.defineClass(name, temp, 0, temp.length, pd);
- パラメータ:
name- クラスの予想されるバイナリ名。不明な場合はnullb- クラス・データを構成するバイト。b.position()からb.position()+b.limit() -1までの位置にあるbyteは、『Java™仮想マシン仕様』で定義される有効なクラス・ファイルの形式を持つ。protectionDomain- クラスのProtectionDomain、またはnull。- 戻り値:
- データから作成された
ClassオブジェクトとProtectionDomain。 - 例外:
ClassFormatError- データが有効なクラスを含まなかった場合。NoClassDefFoundError-nameがnullでなく、bで指定されたクラスの「バイナリ名」と等しくない場合SecurityException- このクラスとは異なる証明書セットを使って署名されたクラスを含むパッケージに、このクラスを追加しようとする場合、またはnameが「java.」で始まる場合。- 導入されたバージョン:
- 1.5
- 関連項目:
defineClass(String, byte[], int, int, ProtectionDomain)
-
resolveClass
protected final void resolveClass(Class<?> c)指定されたクラスをリンクします。 クラス・ローダーはこのメソッドを使って、クラスをリンクします。cクラスがすでにリンクされている場合、このメソッドは単に復帰します。 そうでない場合、『Java™言語仕様』の「Execution」の章で説明しているように、クラスはリンクされます。- パラメータ:
c- リンクするクラス- 例外:
NullPointerException-cがnullの場合。- 関連項目:
defineClass(String, byte[], int, int)
-
findSystemClass
protected final Class<?> findSystemClass(String name) throws ClassNotFoundException指定されたバイナリ名を持つクラスを探して、必要に応じてロードします。このメソッドはシステム・クラス・ローダー(
getSystemClassLoader()を参照)を使ってそのクラスをロードします。 返されるClassオブジェクトは、そのオブジェクトに関連付けられたClassLoaderを1つ以上持つ場合があります。ClassLoaderのサブクラスでは通常、このメソッドを呼び出す必要はありません。これは、ほとんどのクラス・ローダーではfindClass(String)だけをオーバーライドすればよいからです。- パラメータ:
name- クラスのバイナリ名- 戻り値:
- 指定された
nameのClassオブジェクト - 例外:
ClassNotFoundException- クラスが見つからなかった場合- 関連項目:
ClassLoader(ClassLoader),getParent()
-
findLoadedClass
- パラメータ:
name- クラスのバイナリ名- 戻り値:
Classオブジェクト。クラスがロードされていない場合はnull- 導入されたバージョン:
- 1.1
-
setSigners
クラスの署名者を設定します。 このメソッドは、クラスの定義後に呼び出す必要があります。- パラメータ:
c-Classオブジェクトsigners- クラスの署名者- 導入されたバージョン:
- 1.1
-
findResource
protected URL findResource(String moduleName, String name) throws IOExceptionこのクラス・ローダーに定義されたモジュール内のリソースへのURLを返します。 モジュールからのロードをサポートするクラス・ローダー実装は、このメソッドをオーバーライドする必要があります。- APIの注:
- このメソッドは、
Class.getResource、Class.getResourceAsStream、およびModule.getResourceAsStreamメソッドの基礎となります。Module.getResourceAsStreamで指定されたカプセル化の規則の対象ではありません。 - 実装要件:
moduleNameがnullのとき、findResource(String)を呼び出すことによって、デフォルトの実装はリソースを見つけようとします。 そうでなければ、nullを返します。- パラメータ:
moduleName- モジュール名。またはnullを使用して、このクラス・ローダーの「名前のないモジュール」内のリソースを検索name- リソース名- 戻り値:
- リソースへのURL; リソースが見つからない場合、URLを構築してリソースを見つけることができなかった場合、リソースへのアクセスがセキュリティ・マネージャによって拒否された場合、または指定された名前のモジュールがクラス・ローダーに定義されていない場合、
null。 - 例外:
IOException- 入出力エラーが発生した場合- 導入されたバージョン:
- 9
- 関連項目:
ModuleReader.find(String)
-
getResource
指定された名前を持つリソースを検索します。 リソースは、クラス・コードからコード位置に依存しない方法でアクセス可能なデータ(イメージ、オーディオ、テキストなど)です。リソースの名前は、「
/」で区切られたパス名であり、これによってリソースが識別されます。名前付きモジュールのリソースは、
Module.getResourceAsStreamで指定されたカプセル化ルールの影響を受けます。 さらに、リソースが".class"で終わる名前を持つ特殊な場合を除いて、このメソッドは、パッケージがopened無条件で(このメソッドの呼び出し元がリソースと同じモジュール内にあっても)である場合にのみ、名前付きモジュールのパッケージ内のリソースを検索します。- APIの注:
- いくつかのモジュールが同じクラス・ローダーに定義され、複数のモジュールが指定された名前のリソースを含む場合、モジュールが検索される順序は指定されておらず、非常に予測不能な場合があります。 このメソッドをオーバーライドするときは、実装によっていずれかの委譲が
getResources(String)メソッドと確実に一致するようになることをお薦めします。 - 実装要件:
- デフォルトの実装では、最初にリソースの親クラス・ローダーを検索します。親が
nullの場合、仮想マシンに組み込まれているクラス・ローダーのパスが検索されます。 見つからなければ、このメソッドはfindResource(String)を呼び出してリソースを探します。 - パラメータ:
name- リソース名- 戻り値:
- リソースを読み取るための
URLオブジェクト。nullリソースが見つからなかった場合、リソースを見つけるためにURLを構築できなかったか、リソースが無条件に開かれていないパッケージに入っているか、リソースへのアクセスがセキュリティ・マネージャによって拒否されました。 - 例外:
NullPointerException-nameがnullである場合- 導入されたバージョン:
- 1.1
-
getResources
public Enumeration<URL> getResources(String name) throws IOException指定された名前を持つすべてのリソースを検索します。 リソースは、クラス・コードからコード位置に依存しない方法でアクセス可能なデータ(イメージ、オーディオ、テキストなど)です。リソースの名前は、
/で区切られたパス名であり、これによってリソースが識別されます。名前付きモジュールのリソースは、
Module.getResourceAsStreamで指定されたカプセル化ルールの影響を受けます。 さらに、リソースが".class"で終わる名前を持つ特殊な場合を除いて、このメソッドは、パッケージがopened無条件で(このメソッドの呼び出し元がリソースと同じモジュール内にあっても)である場合にのみ、名前付きモジュールのパッケージ内のリソースを検索します。- APIの注:
- 複数のモジュールが同じクラス・ローダーに定義され、複数のモジュールが指定された名前のリソースを含む場合、順序は指定されず、非常に予測できない場合があります。 このメソッドをオーバーライドするときは、実装によっていずれかの委譲が
getResource(String)メソッドと確実に一致するようになることをお薦めします。 これにより、列挙のnextElementメソッドから返される最初の要素が必ず、getResource(String)メソッドが返すリソースと同じものになるはずです。 - 実装要件:
- デフォルトの実装では、最初にリソースの親クラス・ローダーを検索します。親が
nullの場合、仮想マシンに組み込まれているクラス・ローダーのパスが検索されます。 次に、findResources(String)を呼び出して、このクラス・ローダー内の名前のリソースを検索します。 親クラス・ローダーを検索した後にfindResourcesで見つかった要素が検索されたURLを要素とする列挙を返します。 - パラメータ:
name- リソース名- 戻り値:
- リソースの
URLオブジェクトの列挙型。 リソースが見つからなかった場合、列挙は空になる。URLを構築できないリソースが、無条件でオープンされていないパッケージに含まれているか、リソースへのアクセスがセキュリティ・マネージャによって拒否され、列挙型に返されません。 - 例外:
IOException- 入出力エラーが発生した場合NullPointerException-nameがnullである場合- 導入されたバージョン:
- 1.2
-
resources
要素が指定された名前を持つすべてのリソースのURLであるストリームを返します。 リソースは、クラス・コードからコード位置に依存しない方法でアクセス可能なデータ(イメージ、オーディオ、テキストなど)です。リソースの名前は、
/で区切られたパス名であり、これによってリソースが識別されます。リソースは、返されたストリームが評価されるときに配置されます。 評価結果が
IOExceptionの場合、I/O例外はスローされるUncheckedIOExceptionにラップされます。名前付きモジュールのリソースは、
Module.getResourceAsStreamで指定されたカプセル化ルールの影響を受けます。 さらに、リソースが".class"で終わる名前を持つ特殊な場合を除いて、このメソッドは、パッケージがopened無条件で(このメソッドの呼び出し元がリソースと同じモジュール内にあっても)である場合にのみ、名前付きモジュールのパッケージ内のリソースを検索します。- APIの注:
- このメソッドをオーバーライドするときは、実装によっていずれかの委譲が
getResource(String)メソッドと確実に一致するようになることをお薦めします。 これにより、ストリームによって返される最初の要素が、getResource(String)メソッドが返すものと同じリソースであることが保証されます。 - 実装要件:
- デフォルトの実装では、
getResourcesを呼び出して、指定された名前を持つすべてのリソースを検索し、列挙内の要素をソースとして持つストリームを返します。 - パラメータ:
name- リソース名- 戻り値:
- リソース
URLオブジェクトのストリーム。 リソースが見つからない場合、ストリームは空になります。URLを構築できないリソースが、無条件に開かれないパッケージ内にあるか、セキュリティ・マネージャによってリソースへのアクセスが拒否され、ストリームに存在しません。 - 例外:
NullPointerException-nameがnullである場合- 導入されたバージョン:
- 9
-
findResource
指定された名前を持つリソースを検索します。 クラス・ローダーの実装は、このメソッドをオーバーライドする必要があります。名前付きモジュールのリソースの場合、メソッドは
ModulegetResourceAsStreamメソッドで指定されたカプセル化のルールを実装する必要があります。 さらに、パッケージがopenedを無条件に指定していない限り、名前付きモジュールのパッケージ内に非".class"リソースを見つけることはできません。- 実装要件:
- デフォルトの実装では
nullを返します。 - パラメータ:
name- リソース名- 戻り値:
- リソースを読み取るための
URLオブジェクト。nullリソースが見つからなかった場合、リソースを見つけるためにURLを構築できなかったか、リソースが無条件に開かれていないパッケージに入っているか、リソースへのアクセスがセキュリティ・マネージャによって拒否されました。 - 導入されたバージョン:
- 1.2
-
findResources
protected Enumeration<URL> findResources(String name) throws IOException指定された名前を持つすべてのリソースを表すURLオブジェクトの列挙型を返します。 クラス・ローダーの実装は、このメソッドをオーバーライドする必要があります。名前付きモジュールのリソースの場合、メソッドは
ModulegetResourceAsStreamメソッドで指定されたカプセル化のルールを実装する必要があります。 さらに、パッケージがopenedを無条件に指定していない限り、名前付きモジュールのパッケージ内に非".class"リソースを見つけることはできません。- 実装要件:
- デフォルトの実装は、要素を含まない列挙型を返します。
- パラメータ:
name- リソース名- 戻り値:
- リソースの
URLオブジェクトの列挙型。 リソースが見つからなかった場合、列挙は空になる。URLを構築できないリソースが、無条件でオープンされていないパッケージに含まれているか、リソースへのアクセスがセキュリティ・マネージャによって拒否され、列挙型に返されません。 - 例外:
IOException- 入出力エラーが発生した場合- 導入されたバージョン:
- 1.2
-
registerAsParallelCapable
protected static boolean registerAsParallelCapable()呼び出し元を「並列対応」として登録します。 登録が成功するのは、次の条件をすべて満たす場合だけです。- 呼出し元のインスタンスが1つも作成されていない
- 呼出し元のすべてのスーパー・クラス(Objectクラスは除く)が並行可能として登録されている
いったんクラス・ローダーを並行可能として登録すると、それを元に戻す方法はありません。
- 戻り値:
true(呼び出し側が正常に機能するように登録されている場合)およびfalse(そうでない場合)。- 導入されたバージョン:
- 1.7
- 関連項目:
isRegisteredAsParallelCapable()
-
isRegisteredAsParallelCapable
public final boolean isRegisteredAsParallelCapable()このクラス・ローダーが「並列対応」、それ以外の場合はfalseとして登録されている場合はtrueを返します。- 戻り値:
- このクラス・ローダーがパラレルに対応している場合は
true、そうでない場合はfalse。 - 導入されたバージョン:
- 9
- 関連項目:
registerAsParallelCapable()
-
getSystemResource
クラスをロードするために使用される検索パスから、指定された名前のリソースを探します。 このメソッドはシステム・クラス・ローダー(getSystemClassLoader()を参照)を使ってリソースを見つけます。名前付きモジュールのリソースは、
Module.getResourceAsStreamで指定されたカプセル化ルールの影響を受けます。 さらに、リソースが".class"で終わる名前を持つ特殊な場合を除いて、このメソッドは、パッケージが無条件でopenedの場合にのみ、名前付きモジュールのパッケージ内のリソースを検索します。- パラメータ:
name- リソース名- 戻り値:
- リソースへの
URL;nullリソースが見つからない場合、リソースを見つけるためのURLを構築できなかった場合、リソースが無条件に開かれていないパッケージにある場合、またはリソースへのアクセスがセキュリティ・マネージャによって拒否された場合。 - 導入されたバージョン:
- 1.1
-
getSystemResources
public static Enumeration<URL> getSystemResources(String name) throws IOExceptionクラスをロードするために使用される検索パスから、指定された名前のすべてのリソースを探します。 このようにして見つかったリソースは、URLオブジェクトのEnumerationとして返されます。検索順については、
getSystemResource(String)のドキュメントを参照してください。名前付きモジュールのリソースは、
Module.getResourceAsStreamで指定されたカプセル化ルールの影響を受けます。 さらに、リソースが".class"で終わる名前を持つ特殊な場合を除いて、このメソッドは、パッケージが無条件でopenedの場合にのみ、名前付きモジュールのパッケージ内のリソースを検索します。- パラメータ:
name- リソース名- 戻り値:
- リソースの
URLオブジェクトの列挙型。 リソースが見つからなかった場合、列挙は空になる。URLを構築できないリソースが、無条件でオープンされていないパッケージに含まれているか、リソースへのアクセスがセキュリティ・マネージャによって拒否され、列挙型に返されません。 - 例外:
IOException- 入出力エラーが発生した場合- 導入されたバージョン:
- 1.2
-
getResourceAsStream
public InputStream getResourceAsStream(String name)指定されたリソースを読み込む入力ストリームを返します。検索順については、
getResource(String)のドキュメントを参照してください。名前付きモジュールのリソースは、
Module.getResourceAsStreamで指定されたカプセル化ルールの影響を受けます。 さらに、リソースが".class"で終わる名前を持つ特殊な場合を除いて、このメソッドは、パッケージが無条件でopenedの場合にのみ、名前付きモジュールのパッケージ内のリソースを検索します。- パラメータ:
name- リソース名- 戻り値:
- リソースを読み込むための入力ストリーム。
nullリソースが見つからない場合、リソースが無条件に開かれていないパッケージ内にある場合、またはリソースへのアクセスがセキュリティ・マネージャによって拒否された場合。 - 例外:
NullPointerException-nameがnullである場合- 導入されたバージョン:
- 1.1
-
getSystemResourceAsStream
public static InputStream getSystemResourceAsStream(String name)クラスをロードするのに使用される検索パスから、指定された名前のリソースを、読込み用にオープンします。 このメソッドはシステム・クラス・ローダー(getSystemClassLoader()を参照)を使ってリソースを見つけます。名前付きモジュールのリソースは、
Module.getResourceAsStreamで指定されたカプセル化ルールの影響を受けます。 さらに、リソースが".class"で終わる名前を持つ特殊な場合を除いて、このメソッドは、パッケージが無条件でopenedの場合にのみ、名前付きモジュールのパッケージ内のリソースを検索します。- パラメータ:
name- リソース名- 戻り値:
- リソースを読み込むための入力ストリーム。
nullリソースが見つからない場合、リソースが無条件に開かれていないパッケージ内にある場合、またはリソースへのアクセスがセキュリティ・マネージャによって拒否された場合。 - 導入されたバージョン:
- 1.1
-
getParent
public final ClassLoader getParent()委譲のための親クラス・ローダーを返します。 実装によっては、nullを使ってブートストラップ・クラス・ローダーを表すこともできます。 このメソッドは、このクラス・ローダーの親がブートストラップ・クラス・ローダーの場合に、そのような実装でnullを返します。- 戻り値:
- 親の
ClassLoader - 例外:
SecurityException- セキュリティ・マネージャが存在し、呼び出し側クラス・ローダーがnullでなく、このクラス・ローダーの祖先ではなく、呼び出し元にRuntimePermission("getClassLoader")がない場合- 導入されたバージョン:
- 1.2
-
getUnnamedModule
public final Module getUnnamedModule()このクラス・ローダーの名前のないModuleを返します。- 戻り値:
- このクラス・ローダーの無名Module
- 導入されたバージョン:
- 9
- 関連項目:
Module.isNamed()
-
getPlatformClassLoader
public static ClassLoader getPlatformClassLoader()プラットフォーム・クラス・ローダーを返します。 すべての「プラットフォーム・クラス」は、プラットフォーム・クラス・ローダーに表示されます。- 実装上の注意:
- 組み込みプラットフォーム・クラス・ローダーの名前は
"platform"です。 - 戻り値:
- プラットフォーム
ClassLoader。 - 例外:
SecurityException- セキュリティ・マネージャが存在し、呼び出し元クラス・ローダーがnullではなく、呼び出し元クラス・ローダーがプラットフォーム・クラス・ローダーの祖先と同じでも祖先でもなく、呼び出し元にRuntimePermission("getClassLoader")がない場合- 導入されたバージョン:
- 9
-
getSystemClassLoader
public static ClassLoader getSystemClassLoader()システム・クラス・ローダーを返します。 これは、新しいClassLoaderインスタンスのデフォルトの委譲の親で、通常、アプリケーションを起動するためのクラス・ローダーです。このメソッドは、ランタイム起動シーケンスの早い段階で最初に呼び出されます。その時点で、システム・クラス・ローダーが作成されます。 このクラス・ローダーは、メイン・アプリケーション・スレッド(たとえば、メイン・クラスの
mainメソッドを呼び出すスレッド)のコンテキスト・クラス・ローダーになります。デフォルトのシステム・クラス・ローダーは、このクラスの実装依存インスタンスです。
このメソッドが最初に呼び出されたときにシステム・プロパティ"
java.system.class.loader"が定義されている場合、このプロパティの値はシステム・クラス・ローダーとして返されるクラスの名前になります。 また、このクラスは、委譲の親として使用される、ClassLoader型の単一のパラメータを取るpublicコンストラクタを定義する必要があります。 次に、このコンストラクタを使用し、デフォルトのシステム・クラス・ローダーをパラメータに指定して、インスタンスが作成されます。 結果として得られるクラス・ローダーは、システム・クラス・ローダーとして定義されます。 構築中、クラス・ローダーはgetSystemClassLoader()を呼び出さないように十分注意しなければなりません。 システム・クラス・ローダーの循環初期化が検出されると、IllegalStateExceptionがスローされます。- 実装上の注意:
- システム・クラス・ローダーをオーバーライドするシステム・プロパティは、VMがほぼ完全に初期化されるまで検査されません。 起動時にこのメソッドを実行するコードは、システムが完全に初期化されるまで戻り値をキャッシュしないように注意してください。
組み込みシステム・クラス・ローダーの名前は
"app"です。 VMの初期化中にシステム・プロパティ"java.class.path"が読み取られ、クラス・パスが決定されます。 "java.class.path"プロパティの空の値は、初期モジュール(メイン・クラスを含むモジュール)の名前が付いているか、名前がないかによって、異なる方法で解釈されます: 名前付きの場合、組込みシステム・クラス・ローダーにはクラス・パスがなく、アプリケーション・モジュール・パスを使用してクラスおよびリソースを検索します。そうでない場合、名前がない場合は現在の作業ディレクトリへのクラス・パスが設定されます。クラス・パス上のJARファイルには、クラス・パスに含める依存JARファイルを指定するための
Class-Pathマニフェスト属性が含まれる場合があります。Class-Pathエントリは、(詳細は、「JARファイルの仕様」を参照してください。)の妥当性について特定の条件を満たしている必要があります。 無効なClass-Pathエントリは無視されます。 デバッグの目的で、jdk.net.URLClassPath.showIgnoredClassPathEntriesシステム・プロパティがtrueに設定されている場合、無視されたエントリをコンソールに出力できます。 - 戻り値:
- システム
ClassLoader - 例外:
SecurityException- セキュリティ・マネージャが存在し、呼び出し側クラス・ローダーがnullでなく、システム・クラス・ローダーの祖先と同じでも祖先でもなく、呼び出し元にRuntimePermission("getClassLoader")がない場合IllegalStateException- 「java.system.class.loader」プロパティにより指定されたクラス・ローダーの構築時に、再帰的に呼び出される場合。Error- システム・プロパティ「java.system.class.loader」は定義されるが、名前付きクラスをロードできない場合、プロバイダ・クラスは必須コンストラクタを定義しないか、その呼出し時に例外がスローされる。 エラーの根本原因は、Throwable.getCause()メソッドを使用して取得できる。
-
definePackage
protected Package definePackage(String name, String specTitle, String specVersion, String specVendor, String implTitle, String implVersion, String implVendor, URL sealBase)このClassLoaderにnameでパッケージを定義します。「パッケージ名」はクラス・ローダー内で一意でなければならず、一度作成すると再定義または変更することはできません。
クラス・ローダーがバージョン情報などの特定のプロパティを持つパッケージを定義したい場合、クラス・ローダーは
defineClassを呼び出す前にこのdefinePackageメソッドを呼び出す必要があります。 それ以外の場合、defineClassメソッドは、新しく定義されたクラスのパッケージに対応するこのクラス・ローダー内のパッケージを定義します。この定義されたパッケージのプロパティはPackageによって指定されます。- APIの注:
- JARのクラスのパッケージを定義したいクラス・ローダーは、通常、JARマニフェストの仕様と実装のタイトル、バージョン、およびベンダーを使用します。 パッケージがJARマニフェストでsealedとして指定されている場合、JARファイルの
URLは通常sealBaseとして使用されます。 このクラス・ローダーによって定義されたパッケージ'p'のクラスが複数のJARからロードされている場合、Packageオブジェクトには、定義されたパッケージ'p'の最初のクラスおよび最初に読み込まれるパッケージ'p'のJARマニフェストによって異なる情報が含まれます。クラス・ローダーは、「名前付きモジュール」内のパッケージを明示的に定義するためにこのメソッドを呼び出さないことを強く推奨します。代わりに、クラスが「定義されている」のときにパッケージが自動的に定義されます。
Packageを明示的に定義することが望ましい場合は、名前付きモジュールのすべてのパッケージがPackageで指定されたプロパティで定義されていることを確認する必要があります。 さもなければ、名前付きモジュール内のいくつかのPackageオブジェクトは、例えば、異なるシール・ベースでシールされてもよい。 - パラメータ:
name- 「パッケージ名」specTitle- 仕様のタイトルspecVersion- 仕様のバージョンspecVendor- 仕様のベンダーimplTitle- 実装のタイトルimplVersion- 実装のバージョンimplVendor- 実装のベンダーsealBase-nullでない場合、このパッケージは指定されたコード・ソースURLオブジェクトに関して密封されます。 そうでない場合、パッケージはシールされない- 戻り値:
- 新しく定義された
Packageオブジェクト - 例外:
NullPointerException-nameがnullの場合。IllegalArgumentException- 指定されたnameのパッケージがこのクラス・ローダーによってすでに定義されている場合- Java Virtual Machine仕様を参照してください:
-
5.3 作成およびロード
- 導入されたバージョン:
- 1.2
- 関連項目:
- JARファイルの仕様: パッケージ・シーリング
-
getDefinedPackage
このクラス・ローダーによって定義されたnameのPackageを返します。- パラメータ:
name- 「パッケージ名」- 戻り値:
- このクラス・ローダーによって定義された指定された名前の
Package、または見つからなければnull - 例外:
NullPointerException-nameがnullの場合。- Java Virtual Machine仕様を参照してください:
-
5.3 作成およびロード
- 導入されたバージョン:
- 9
-
getDefinedPackages
public final Package[] getDefinedPackages()このクラス・ローダーによって定義されたすべてのPackageを返します。 返される配列には、同じ名前の重複したPackageがありません。- APIの注:
- このメソッドは、既存の
getPackages()メソッドとの一貫性のために、SetまたはStreamではなく配列を返します。 - 戻り値:
- このクラス・ローダーによって定義された
Packageオブジェクトの配列。このクラス・ローダーによってパッケージが定義されていない場合は、長さがゼロの配列を返します。 - Java Virtual Machine仕様を参照してください:
-
5.3 作成およびロード
- 導入されたバージョン:
- 9
-
getPackage
@Deprecated(since="9")protected Package getPackage(String name)非推奨。複数のクラス・ローダーが互いに委譲して同じパッケージ名を持つクラスを定義し、そのようなローダーの1つがgetPackageのルックアップ動作に依存して親ローダーからPackageを返す場合、Packageによって公開されるプロパティは残りのプログラムで期待どおりにならない場合があります。 たとえば、Packageは、子ローダーによって定義されたpackage-info.classファイルに注釈が存在する場合でも、親ローダーによって定義されたpackage-info.classファイルの注釈のみを公開します。 より堅牢なアプローチは、指定されたクラス・ローダーのPackageを返すgetDefinedPackage(java.lang.String)メソッドを使用することです。このクラス・ローダーとその祖先のnameによるパッケージを検索します。このクラス・ローダーが指定された名前の
Packageを定義する場合、Packageが返されます。 それ以外の場合、このクラス・ローダーの祖先は、指定された名前のPackageの(親による親)を再帰的に検索されます。- APIの注:
platform class loaderはアプリケーション・クラス・ローダーに委譲することができますが、アプリケーション・クラス・ローダーはその祖先ではありません。 プラットフォーム・クラス・ローダーで呼び出された場合、このメソッドはアプリケーション・クラス・ローダーに定義されたパッケージを検出しません。- パラメータ:
name- 「パッケージ名」- 戻り値:
- このクラス・ローダーまたはその祖先によって定義された指定された名前の
Package、または見つからない場合はnull。 - 例外:
NullPointerException-nameがnullの場合。- 導入されたバージョン:
- 1.2
- 関連項目:
getDefinedPackage(String)
-
getPackages
protected パッケージ[] getPackages()このクラス・ローダーとその祖先によって定義されたすべてのPackageを返します。 返される配列には、同じパッケージ名の複数のPackageオブジェクトが含まれ、それぞれがクラス・ローダー階層の異なるクラス・ローダーによって定義されます。- APIの注:
platform class loaderは、アプリケーション・クラス・ローダーに委譲することができます。 言い換えれば、アプリケーション・クラス・ローダーに定義されたモジュール内のパッケージは、プラットフォーム・クラス・ローダーに表示されることがあります。 一方、アプリケーション・クラス・ローダーはその祖先ではないため、プラットフォーム・クラス・ローダーで呼び出されると、このメソッドはアプリケーション・クラス・ローダーに定義されたパッケージを返しません。- 戻り値:
- このクラス・ローダーとその祖先によって定義された
Packageオブジェクトの配列 - 導入されたバージョン:
- 1.2
- 関連項目:
getDefinedPackages()
-
findLibrary
ネイティブ・ライブラリの絶対パス名を返します。 VMは、このメソッドを呼び出して、このクラス・ローダーによってロードされたクラスのネイティブ・ライブラリを検索します。 このメソッドがnullを返す場合、VMは「java.library.path」プロパティで指定されたパスに従ってライブラリを検索します。- パラメータ:
libname- ライブラリ名- 戻り値:
- ネイティブ・ライブラリの絶対パス
- 導入されたバージョン:
- 1.2
- 関連項目:
System.loadLibrary(String),System.mapLibraryName(String)
-
setDefaultAssertionStatus
public void setDefaultAssertionStatus(boolean enabled)このクラス・ローダーのデフォルトのアサーション・ステータスを設定します。 この設定により、将来、このクラス・ローダーによってロードされ初期化されるクラスのアサーションがデフォルトで有効か無効かが決まります。 この設定をパッケージ単位またはクラス単位でオーバーライドするには、setPackageAssertionStatus(String, boolean)またはsetClassAssertionStatus(String, boolean)を呼び出します。- パラメータ:
enabled- このクラス・ローダーによりロードされるクラスのアサーションが、デフォルトで有効な場合はtrue、デフォルトで無効な場合はfalse。- 導入されたバージョン:
- 1.4
-
setPackageAssertionStatus
public void setPackageAssertionStatus(String packageName, boolean enabled)指定されたパッケージ・デフォルトのアサーション・ステータスを設定します。 パッケージ・デフォルトのアサーション・ステータスにより、指定されたパッケージまたはその「サブパッケージ」のどれかに属する、将来初期化されるクラスのアサーション・ステータスが決まります。pという名前のパッケージのサブパッケージは、すべて名前が「
p.」で始まります。 たとえば、javax.swing.textはjavax.swingのサブパッケージであり、java.utilとjava.lang.reflectはどちらもjavaのサブパッケージです。1つのクラスに複数のパッケージ・デフォルトが適用される場合は、そのクラスにもっとも関連性の高いパッケージ・デフォルトが、ほかのパッケージ・デフォルトに優先して使用されます。 たとえば、
javax.langとjavax.lang.reflectの両方にパッケージ・デフォルトが関連付けられている場合、後者のパッケージ・デフォルトはjavax.lang.reflect内のクラスに適用されます。パッケージ・デフォルトは、クラス・ローダーのデフォルトのアサーション・ステータスよりも優先されます。ただし、
setClassAssertionStatus(String, boolean)を呼び出すことで、クラス単位でオーバーライドできます。- パラメータ:
packageName- パッケージ・デフォルトのアサーション・ステータスを設定するパッケージ名。null値は「カレント」である無名パッケージを示す(『Java™言語仕様』のセクション7.4.2を参照。)enabled- このクラス・ローダーによりロードされ、指定されたパッケージまたはそのサブパッケージのどれかに属するクラスが、デフォルトで有効なアサーションを保持する場合はtrue、デフォルトで無効なアサーションを保持する場合はfalse。- 導入されたバージョン:
- 1.4
-
setClassAssertionStatus
public void setClassAssertionStatus(String className, boolean enabled)このクラス・ローダーの指定されたトップレベル・クラスおよびそこに含まれるネストされたクラス内に対して、目的のアサーション・ステータスを設定します。 この設定は、クラス・ローダーのデフォルトのアサーション・ステータス、およびパッケージ単位で適用可能なデフォルトに優先されます。 指定されたクラスが初期化済みの場合、このメソッドは無効になります (クラスの初期化後にアサーション・ステータスを変更することはできないため)。指定されたクラスがトップ・レベルのクラスではない場合、この呼出しは、どのクラスのアサーション・ステータスに対しても影響を与えません。
- パラメータ:
className- アサーション・ステータスを設定するトップ・レベルのクラスの完全指定クラス名。enabled- 初期化時に、指定されたクラスでアサーションを有効にする場合はtrue、アサーションを無効にする場合はfalse。- 導入されたバージョン:
- 1.4
-
clearAssertionStatus
public void clearAssertionStatus()このクラス・ローダーのデフォルトのアサーション・ステータスをfalseに設定し、クラス・ローダーに関連付けられたパッケージ・デフォルトまたはクラスのアサーション・ステータス設定をすべて破棄します。 このメソッドを利用すると、クラス・ローダーがコマンド行または永続的なアサーション・ステータス設定をすべて無視するため、「クリーンな状態で」起動できます。- 導入されたバージョン:
- 1.4
-