ANDROID.RLK.SQLCON

RLK (リソースリーク) 指摘は、割り当てられたリソースが使用後に適切に破棄されなかった場合に報告されます。ANDROID.RLK.SQLCON は、SQL 接続が終了時に閉じられていないことを示します。

脆弱性とリスク

ストリーム、接続、グラフィックオブジェクトなどのリソースは、明示的に閉じられる必要があります。閉じる操作により、トランザクションをアンブロックすることや、ファイルシステム内のファイルの変更をフラッシュすることができます。リソースは、最終的にはガーベッジコレクタにより閉じられますが、ガーベッジコレクションが開始される前にリソースの枯渇が発生する可能性があります。リソースの性質によっては、別のリソース割り当ての失敗時に、さまざまな例外がスローされます。次のような例外があります:java.io.FileNotFoundException:開かれたファイルが多すぎるか、データベース接続が多すぎます。

軽減と防止

重要でないと考えられるリソースであっても、メソッドを持つリソースはすべて明示的に閉じてください。こうすることで、将来的なコード変更時にもこのようなエラーから安全が保たれます。

例 1

コピー
     protected void onCreate(Bundle bundle) {
         super.onCreate(bundle);
         final SQLiteDatabase database = openOrCreateDatabase(DB_NAME, Context.MODE_PRIVATE, null);
         final Cursor query = database.query(DATABASE_TABLE,
                                             new String[]{KEY_FILE, KEY_DATE, KEY_COMMENT},
                                             null,
                                             null,
                                             null,
                                             null,
                                             KEY_DATE + " asc");
         startManagingCursor(query);
 
         ListAdapter adapter = new SimpleCursorAdapter(this,
                                                       android.R.layout.simple_list_item_1,
                                                       query,
                                                       new String[]{Contacts.People.NAME},
                                                       new int[]{android.R.id.text1});
         setListAdapter(adapter);
     }

接続 'database' が終了時に閉じられないため、ANDROID.RLK.SQLCON が 32 行目のスニペットに対して報告されています。

関連チェッカー

拡張機能

このチェッカーは、Klocwork knowledge base (ナレッジベース) を利用して拡張できます。詳細については、Java 解析のチューニングを参照してください。