오류 처리:java.lang.IllegalStateException: databases already closed

3689 단어
Android Error 처리:java.lang.IllegalStateException: databases  already closed
오늘 Android 기반 가져오기 2.x 버전 SDK 프로젝트, 실행 중 오류가 발생했습니다. 오류는 다음과 같습니다.
11-18 16:58:56.595:E/AndroidRuntime(22991): java.lang.RuntimeException: Unable to start servicexxx.xxxx.service.LocalService@41985638 with Intent {act=xxx.xxx.xxx.APP_SERVICE (has extras) }: java.lang.IllegalStateException:database/data/data/xxx.xxx.xxx/databases/xxx.db (conn# 0) already closed
데이터베이스 작업 부분에 문제가 있는 것으로 판단, 데이터베이스 작업 부분 파일 코드 DBHelper.java는 다음과 같습니다.
package org.yousee.utils;


import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
/**
 *  
 */
public class DBHelper extends SQLiteOpenHelper {
	private Cursor c = null;
	private static final String CREATE_TAB = "create table "
		+ "music(_id integer primary key autoincrement,music_id integer,clicks integer," + "latest text)";
	private static final String TAB_NAME = "list";
	private SQLiteDatabase db = null;
	public DBHelper(Context context, String name, CursorFactory factory,int version) {
		super(context, name, factory, version);
	}

	@Override
	public void onCreate(SQLiteDatabase db) {
		this.db = db;
		db.execSQL(CREATE_TAB);
	}
	
	public void insert(ContentValues values){
		SQLiteDatabase db = this.getWritableDatabase();
		db.insert(TAB_NAME, null, values);
		db.close();// this.close()
	}

	public void update(ContentValues values,int id){
		SQLiteDatabase db = this.getWritableDatabase();
		db.update(TAB_NAME, values, "music_id="+id, null);
		db.close();// this.close()

	}
	
	public void delete(int id){
		if (db == null){
			db = getWritableDatabase();
		}
		db.delete(TAB_NAME, "music_id=?", new String[]{String.valueOf(id)});
	}
	
	public Cursor query(int id){
		SQLiteDatabase db = getReadableDatabase();
		c = db.query(TAB_NAME, null, "music_id=?", new String[]{String.valueOf(id)}, null, null, null);
		db.close();// this.close()

		return c;
	}
	
	public Cursor queryByClicks(){// 
		SQLiteDatabase db = getReadableDatabase();
		c = db.query(TAB_NAME, null, null, null, null, null, "clicks desc");
		return c;
	}
	
	public Cursor queryRecently(){// 
		SQLiteDatabase db = getReadableDatabase();
		c = db.query(TAB_NAME, null, null, null, null, null, "latest desc");
		return c;
	}
	
	public void close(){
		if (db != null){
			db.close();// this.close()

			db=null;
		}
		if (c!=null){
			c.close();
			c=null;
		}
	}
	
	@Override
	public void onUpgrade(SQLiteDatabase arg0, int arg1, int arg2) {

	}

}

분석 결과 데이터베이스를 닫을 때 SQLiteDatabase를 직접 호출한 것으로 나타났습니다.close () 메서드.
오류의 구체적인 원인은 다음과 같습니다.
SQLiteDatabase를 호출하는 경우close()가 SQLiteOpenHelper를 대체합니다.close().그러면 SQLite OpenHelper는 helper를 통해 얻은 DB가 닫혔는지 (getReadable Database 또는 getWritable Database) 알지 못합니다.
요약:
1、SQLiteOpenHelper.close()는 비동기적이며 SQLiteDatabase는 비동기적입니다.close () 아니요.
2. 안드로이드가 제공하는 SQLite OpenHelper를 사용할 때 getReadable Database나 getWritable Database를 통해 얻은 것은 같은 대상이다. 유일한 것은 하드디스크가 부족하면 getWritable Database를 호출할 수 없고 getReadable Database만 호출할 수 있다는 것이다.
3. Android에서 제공하는 데이터베이스 인터페이스를 사용하여 데이터베이스 작업을 할 때는 Andoid의 규칙을 따라야 합니다.다중 스레드에서 주의해야 하기 때문에 대상을 대상으로 하는 습관을 기르고helper의close 방법으로 데이터베이스를 닫습니다.(누가 제공한 데이터는 누구의 방법으로 데이터를 조작한다)
인터넷에서 유사한 문제가 발견되었다.
http://androiddev.orkitra.com/?p=30756
http://stackoverflow.com/questions/6535908/android-sqlite-sqliteopenhelper-error-illegalstateexception-db-already-clo

좋은 웹페이지 즐겨찾기