付録A Javaヒープメモリのリークを起こしやすいJavaAPIクラス
JavaAPIクラスを使用した場合,JavaAPIクラスのインスタンスがJavaヒープメモリ上に作成されます。しかし,表A-1および表A-2に示すJavaAPIクラスのメソッドを使用して,表の条件に該当する場合,JavaAPIクラス以外のインスタンスもJavaヒープメモリ上に作成されます。
作成されたユーザ作成クラスのインスタンスは,JavaAPIクラスが削除されるまでJavaヒープメモリ上に残ります。このため,ユーザが意識しない間にJavaヒープメモリの使用量が増え,Javaヒープメモリがリークするおそれがあるので注意してください。
ただし,表A-2のJavaAPIクラスについては,ユーザ作成クラスのインスタンスを削除することもできます。
Javaヒープメモリがリークしやすいクラス一覧について,インスタンスの削除方法がある場合とない場合に分けて表に示します。表A-2については,ユーザ作成のインスタンスの削除方法も示します。
- 参考
-
Javaヒープメモリのリークを起こしやすいJavaAPIクラスや条件,およびユーザ作成クラスのインスタンス削除方法については,ご使用のアプリケーションサーバのバージョンによって変わる場合があります。
JavaAPIクラス名 |
Javaヒープメモリにユーザ作成クラスのインスタンスを作成する条件 |
---|---|
java.lang.ClassLoader |
defineClass()メソッドの引数に指定したProtectionDomainがユーザ作成クラスと関連づけられている場合。 |
java.net.URL |
URLクラスインスタンスを生成する際,URLStreamHandlerFactoryが作成するURLStreamHanderクラスがユーザ作成クラスの場合。 |
java.text.DateFormat |
DateFormatクラスを継承したユーザ作成クラスのコンストラクタでsuper()を呼び出した場合。 |
java.util.logging.Level |
Levelクラスを継承したユーザ作成クラスのコンストラクタでsuper()を呼び出した場合。 |
java.util.logging.LogManager |
addLogger()メソッドの引数にLoggerクラスを継承したユーザ作成クラスを指定した場合。 |
java.util.logging.Logger |
Loggerクラスを継承したユーザ作成クラスでgetAnonymousLogger()メソッドや setParent()メソッドを呼び出した場合。 |
javax.accessibility.AccessibleBundle |
toDisplayString()メソッドの引数に指定したリソースバンドル名に対応するユーザ実装のクラスで,そのユーザ実装のクラス内で保持しておくキーと値のペアの値に,ユーザクラスのオブジェクトを設定している場合。 |
javax.print.attribute.standard.MediaSize |
MediaSizeクラスを継承したユーザ作成クラスのコンストラクタでsuper()を呼び出した場合。 |
java.rmi.server.UnicastRemoteObject |
exportObject()メソッドの引数(RMIClientSocketFactory,RMIServerSocketFactory)にユーザ作成クラスを指定した場合。 |
JavaAPIクラス名 |
Javaヒープメモリにユーザ作成クラスのインスタンスを作成する条件 |
ユーザ作成クラスのインスタンス削除方法 |
---|---|---|
java.beans.Introspector |
getBeanInfo()メソッドの引数(beanClass)にユーザ作成クラスを指定した場合。 |
flushCaches()メソッドやflushFromCaches()メソッドを実行する。 |
java.beans.PropertyEditorManager |
registerEditor()メソッドの引数(editorClass)にユーザ作成クラスを指定した場合。 |
registerEditor()メソッドのeditorClassにnullを指定する。 |
java.util.logging.Logger |
addHandler()メソッドの引数にHandlerクラスを継承したユーザ作成クラスを指定した場合。 |
removeHandler()メソッドを実行する。 |
javax.imageio.ImageReader |
addIIOReadWarningListener()メソッドの引数にIIOReadWarningListenerクラスを継承したユーザ作成クラスを指定した場合。 |
removeIIOReadWarningListener()メソッドを実行する。 |
addIIOReadProgressListener()メソッドの引数にIIOReadProgressListenerクラスを継承したユーザ作成クラスを指定した場合。 |
removeIIOReadProgressListener()メソッドを実行する。 |
|
addIIOReadUpdateListener()メソッドの引数にIIOReadUpdateListenerクラスを継承したユーザ作成クラスを指定した場合。 |
removeIIOReadUpdateListener()メソッドを実行する。 |
|
javax.imageio.ImageWriter |
addIIOWriteProgressListener()メソッドの引数にIIOWriteProgressListenerクラスを継承したユーザ作成クラスを指定した場合。 |
removeIIOWriteProgressListener()メソッドを実行する。 |
addIIOWriteWarningListener()メソッドの引数にIIOWriteWarningListenerクラスを継承したユーザ作成クラスを指定した場合。 |
removeIIOWriteWarningListener()メソッドを実行する。 |
|
javax.naming.InitialContext |
addToEnvironment()メソッドの引数(propVal)にユーザ作成クラスを指定した場合。 |
removeFromEnvironment()メソッドを実行する。 |
javax.naming.spi.NamingManager |
getContinuationContext()メソッドの引数にユーザ作成クラスを指定した場合。 |
得られたContextのclose()を実装してsuper()を実行する。 |
javax.print.attribute.HashAttributeSet |
add()メソッドの引数にユーザ作成クラスを指定した場合。 |
remove(Attribute)メソッドや remove(Class)メソッドを実行する。 |