gpt4 book ai didi

android - 为什么我的应用程序在 android 中抛出终结器异常?

转载 作者:搜寻专家 更新时间:2023-10-30 22:03:44 25 4
gpt4 key购买 nike

我有一个应用程序,其中经常抛出这个异常......

04-25 18:47:38.024: INFO/dalvikvm(10290): Uncaught exception thrown by finalizer (will be discarded):
04-25 18:47:38.035: INFO/dalvikvm(10290): Ljava/lang/IllegalStateException;: Finalizing cursor android.database.sqlite.SQLiteCursor@44dd1e68 on null that has not been deactivated or closed
04-25 18:47:38.035: INFO/dalvikvm(10290): at android.database.sqlite.SQLiteCursor.finalize(SQLiteCursor.java:596)
04-25 18:47:38.035: INFO/dalvikvm(10290): at dalvik.system.NativeStart.run(Native Method)
04-25 18:47:38.044: INFO/dalvikvm(10290): Uncaught exception thrown by finalizer (will be discarded):
04-25 18:47:38.064: INFO/dalvikvm(10290): Ljava/lang/IllegalStateException;: Finalizing cursor android.database.sqlite.SQLiteCursor@44e4c048 on null that has not been deactivated or closed
04-25 18:47:38.064: INFO/dalvikvm(10290): at android.database.sqlite.SQLiteCursor.finalize(SQLiteCursor.java:596)
04-25 18:47:38.064: INFO/dalvikvm(10290): at dalvik.system.NativeStart.run(Native Method)
04-25 18:47:38.074: INFO/dalvikvm(10290): Uncaught exception thrown by finalizer (will be discarded):
04-25 18:47:38.094: INFO/dalvikvm(10290): Ljava/lang/IllegalStateException;: Finalizing cursor android.database.sqlite.SQLiteCursor@44e35310 on null that has not been deactivated or closed
04-25 18:47:38.094: INFO/dalvikvm(10290): at android.database.sqlite.SQLiteCursor.finalize(SQLiteCursor.java:596)
04-25 18:47:38.094: INFO/dalvikvm(10290): at dalvik.system.NativeStart.run(Native Method)
04-25 18:47:38.104: INFO/dalvikvm(10290): Uncaught exception thrown by finalizer (will be discarded):
04-25 18:47:38.104: INFO/dalvikvm(10290): Ljava/lang/IllegalStateException;: Finalizing cursor android.database.sqlite.SQLiteCursor@44e7f738 on null that has not been deactivated or closed
04-25 18:47:38.104: INFO/dalvikvm(10290): at android.database.sqlite.SQLiteCursor.finalize(SQLiteCursor.java:596)
04-25 18:47:38.104: INFO/dalvikvm(10290): at dalvik.system.NativeStart.run(Native Method)
04-25 18:47:38.114: INFO/dalvikvm(10290): Uncaught exception thrown by finalizer (will be discarded):
04-25 18:47:38.136: INFO/dalvikvm(10290): Ljava/lang/IllegalStateException;: Finalizing cursor android.database.sqlite.SQLiteCursor@44e04a90 on null that has not been deactivated or closed
04-25 18:47:38.136: INFO/dalvikvm(10290): at android.database.sqlite.SQLiteCursor.finalize(SQLiteCursor.java:596)
04-25 18:47:38.136: INFO/dalvikvm(10290): at dalvik.system.NativeStart.run(Native Method)
04-25 18:47:38.155: INFO/dalvikvm(10290): Uncaught exception thrown by finalizer (will be discarded):
04-25 18:47:38.155: INFO/dalvikvm(10290): Ljava/lang/IllegalStateException;: Finalizing cursor android.database.sqlite.SQLiteCursor@44e944f0 on null that has not been deactivated or closed
04-25 18:47:38.155: INFO/dalvikvm(10290): at android.database.sqlite.SQLiteCursor.finalize(SQLiteCursor.java:596)
04-25 18:47:38.155: INFO/dalvikvm(10290): at dalvik.system.NativeStart.run(Native Method)
04-25 18:47:38.164: INFO/dalvikvm(10290): Uncaught exception thrown by finalizer (will be discarded):
04-25 18:47:38.184: INFO/dalvikvm(10290): Ljava/lang/IllegalStateException;: Finalizing cursor android.database.sqlite.SQLiteCursor@44e90548 on null that has not been deactivated or closed
04-25 18:47:38.184: INFO/dalvikvm(10290): at android.database.sqlite.SQLiteCursor.finalize(SQLiteCursor.java:596)
04-25 18:47:38.184: INFO/dalvikvm(10290): at dalvik.system.NativeStart.run(Native Method)
04-25 18:47:38.194: INFO/dalvikvm(10290): Uncaught exception thrown by finalizer (will be discarded):
04-25 18:47:38.194: INFO/dalvikvm(10290): Ljava/lang/IllegalStateException;: Finalizing cursor android.database.sqlite.SQLiteCursor@44e6b0c8 on null that has not been deactivated or closed
04-25 18:47:38.194: INFO/dalvikvm(10290): at android.database.sqlite.SQLiteCursor.finalize(SQLiteCursor.java:596)
04-25 18:47:38.194: INFO/dalvikvm(10290): at dalvik.system.NativeStart.run(Native Method)
04-25 18:47:38.204: INFO/dalvikvm(10290): Uncaught exception thrown by finalizer (will be discarded):
04-25 18:47:38.225: INFO/dalvikvm(10290): Ljava/lang/IllegalStateException;: Finalizing cursor android.database.sqlite.SQLiteCursor@44e4af40 on null that has not been deactivated or closed
04-25 18:47:38.237: INFO/dalvikvm(10290): at android.database.sqlite.SQLiteCursor.finalize(SQLiteCursor.java:596)
04-25 18:47:38.245: INFO/dalvikvm(10290): at dalvik.system.NativeStart.run(Native Method)

我不明白为什么会这样。我已经关闭了所有游标,而且我已经关闭了数据库之前的游标...即 c.close() 出现在 db.close()

之前

可能是什么问题?

提前致谢。

编辑:我认为这个类导致了异常,因为它是唯一处理数据库的类

package com.helios.NauticDates;

import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;

import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.util.Log;

public class HandleDatabase {

public void executeSql(String query) {
SQLiteDatabase db = SQLiteDatabase.openDatabase(
"/data/data/com.helios.NauticDates/CalendarEvent.sqlitedb",
null, SQLiteDatabase.OPEN_READWRITE);
db.execSQL(query);
db.close();
}

public boolean checkCategory(String name) {
// TODO Auto-generated method stub
SQLiteDatabase db = SQLiteDatabase.openDatabase(
"/data/data/com.helios.NauticDates/CalendarEvent.sqlitedb",
null, SQLiteDatabase.OPEN_READWRITE);
String query = "select * from EventCategories where categoryname ='"
+ name + "'";
Cursor c = db.rawQuery(query, null);
if (c.getCount() == 0) {
c.close();
db.close();
return true;
} else {
c.close();
db.close();
return false;
}
}

public String[][] getData(String[] columnnames, String tablename) {
SQLiteDatabase db = SQLiteDatabase.openDatabase(
"/data/data/com.helios.NauticDates/CalendarEvent.sqlitedb",
null, SQLiteDatabase.OPEN_READWRITE);
String query = "select ";
for (int i = 0; i < columnnames.length; i++) {
if (i == columnnames.length - 1)
query += columnnames[i] + " ";
else
query += columnnames[i] + ",";
}
query += "from " + tablename + " where eventid=128";
Cursor c = db.rawQuery(query, null);
String[][] result = new String[c.getColumnCount()][c.getCount()];
for (int i = 0; i < c.getColumnCount(); i++) {
c.moveToFirst();
for (int j = 0; j < c.getCount(); j++) {
result[i][j] = c.getString(c.getColumnIndex(columnnames[i]));
Log.i("getdata", result[i][j]);
c.moveToNext();
}
}
c.close();
db.close();
return result;
}

public boolean checkIfThereIsEvent(String cdate, Date currentdate) {
Date enddate = (Date) currentdate.clone();
enddate.setHours(0);
enddate.setMinutes(0);
enddate.setSeconds(0);
String edate = (String) android.text.format.DateFormat.format(
"yyyy-MM-dd", enddate);

Log.i("handledatabase", cdate + "-" + edate);
SQLiteDatabase db = SQLiteDatabase.openDatabase(
"/data/data/com.helios.NauticDates/CalendarEvent.sqlitedb",
null, SQLiteDatabase.OPEN_READWRITE);
String query = "SELECT datetime(startdat, 'unixepoch') AS std, datetime(enddat, 'unixepoch') AS end FROM EventDetails WHERE ((std <= '"
+ cdate
+ "' AND end >= '"
+ cdate
+ "' )||( date(enddat,'unixepoch') = '1970-01-01' AND date(startdat,'unixepoch') = '"
+ edate + "')) LIMIT 1";
Log.i("thequery", query);
Cursor c = db.rawQuery(query, null);
if (c.getCount() > 0) {
c.close();
db.close();
return true;
}
{
c.close();
db.close();
return false;
}
}

public boolean checkEventInDatabase(String dateofchange, String eventid) {
SQLiteDatabase db = SQLiteDatabase.openDatabase(
"/data/data/com.helios.NauticDates/CalendarEvent.sqlitedb",
null, SQLiteDatabase.OPEN_READWRITE);
String query = "select * from EventDetails where eventid='"+eventid+"' limit 1";
Cursor c = db.rawQuery(query, null);
if(c.getCount()==0){
c.close();
db.close();
return false;
}
else{
query = "select * from EventDetails where eventid='"+eventid+"'and changed='"+dateofchange+"' limit 1";
c= db.rawQuery(query, null);
if(c.getCount()>0){
c.close();
db.close();
return true;
}
else{
c.close();
db.close();
return true;
}
}
}

public boolean checkIfEventChanged(String dateofchange, String eventid) {
SQLiteDatabase db = SQLiteDatabase.openDatabase(
"/data/data/com.helios.NauticDates/CalendarEvent.sqlitedb",
null, SQLiteDatabase.OPEN_READWRITE);
String query = "select * from EventDetails where eventid='"+eventid+"'and changed='"+dateofchange+"' limit 1";
Cursor c= db.rawQuery(query, null);
if(c.getCount()>0){
c.close();
db.close();
return false;
}
else{
c.close();
db.close();
return true;
}
}
}

最佳答案

您在 checkIfThereIsEvent() 的末尾缺少一个 else

如果这还不能解决问题,只需通过调用 Log 记录您自己打开的每个 Cursor,然后比较日志条目以确定哪个 游标是被泄露的。

还有:

  • 永远不要硬连线路径。摆脱 /data/data/com.helios.NauticDates。使用 SQLiteOpenHelper 或使用 getDatabasePath()
  • 以这种方式不断打开和关闭数据库没有任何值(value)。请考虑使用 SQLiteOpenHelper,将这些方法放在该类上,并让您的 SQLiteOpenHelper 保持更长时间(例如,您的 Activity 或服务的生命周期,或整个应用程序的单例)

关于android - 为什么我的应用程序在 android 中抛出终结器异常?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5778462/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com