关于CursorWindowAllocatoinException有很多问题:
所有这些都表明游标必须在使用后关闭。但这并没有解决我的问题。这是我的代码:
String query = "select serial from tbl1 union select serial from tbl2 union select serial from tbl3";
SQLiteDatabase db = null;
Cursor cur = null;
try {
SettingsDatabaseHelper dal = new SettingsDatabaseHelper(
c);
db = dal.getReadableDatabase();
cur = db.rawQuery(query, null);
int numRows = cur.getCount();
if (numRows > 0) {
cur.moveToFirst();
int serialIdx = cur.getColumnIndexOrThrow("serial");
for (boolean hasItem = cur.moveToFirst(); hasItem; hasItem = cur
.moveToNext()) {
String serial = cur.getString(serialIdx);
if (Validator.getInstance().isValidSerial(serial))
serials.add(serial);
}
}
} finally {
if (cur != null)
cur.close();
if (db != null)
db.close();
}
我每隔几秒运行一次这个方法。半小时后,我在CursorWindowAllocationException
中获得int numRows=cur.getCount();
,然后我的服务停止。
由于我关闭了光标,因此我的Helper类可能存在问题。这是代码:
public class SettingsDatabaseHelper extends SQLiteOpenHelper {
private static final String DATABASE_NAME = "mydb.db";
private static final int DATABASE_VERSION = 1;
private static final String TBL_CREATE="create table...";
public SettingsDatabaseHelper(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
@Override
public void onCreate(SQLiteDatabase database) {
database.execSQL(TBL_CREATE);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
onCreate(db);
}
}
如何防止抛出此异常?
答案 0 :(得分:1)
我是从服务查询数据库的。当我从一项活动中做到这一点时,问题再也没有发生过了。
除了查询,我还在同一服务中的串口读取。也许那导致了这个问题。但是,当我使用活动而不是服务时,问题再也没有发生过。
答案 1 :(得分:0)
我从Android媒体商店加载超过500首歌曲时,在我的应用程序中遇到了同样的问题。
关闭光标不会解决您的问题。
你应该使用AsyncTask.。 在doInBackground方法中编写用于从游标中检索值的代码。
公共类CursorLoader扩展了AsyncTask {
@Override
protected Void doInBackground(Void... params) {
String query = "select serial from tbl1 union select serial from tbl2 union select serial from tbl3";
SQLiteDatabase db = null;
Cursor cur = null;
try {
SettingsDatabaseHelper dal = new SettingsDatabaseHelper(
c);
db = dal.getReadableDatabase();
cur = db.rawQuery(query, null);
int numRows = cur.getCount();
if (numRows > 0) {
cur.moveToFirst();
int serialIdx = cur.getColumnIndexOrThrow("serial");
for (boolean hasItem = cur.moveToFirst(); hasItem; hasItem = cur
.moveToNext()) {
String serial = cur.getString(serialIdx);
if (Validator.getInstance().isValidSerial(serial))
serials.add(serial);
}
}
} finally {
if (cur != null)
cur.close();
if (db != null)
db.close();
}
return null;
}
@Override
protected void onPreExecute() {
}
@Override
protected void onPostExecute(Void result) {
}
答案 2 :(得分:0)
我遇到了同样的问题,而我正在使用forever循环在服务类中调用DATA BASE。
我的代码就像:
service ()
{
void run()
{
while(conditionisTrue)
{
db.getRecord(); //I remove this code from here and put it in the start of service c
}
}
}