gpt4 book ai didi

java - 拍照时数据库泄漏。 SQLiteDatabase 创建且从未关闭。安卓、Java、SQLite

转载 作者:行者123 更新时间:2023-12-01 16:02:21 25 4
gpt4 key购买 nike

再次向您问好。我在拍照时遇到一个小问题。我有一个按钮可以调用相机,成功拍照,然后返回到我的报名表。我唯一的问题是按下按钮调用相机时发生的数据库泄漏。我的代码看起来有点像这样。

public void takephoto(){

Intent in = new
Intent(this, takephoto.class);
startActivityForResult(in,1);
}

以下是如何打开数据库的 fragment :

 public journalDbAdapter open() throws SQLException {
mDbHelper = new DatabaseHelper(mCtx);
mDb = mDbHelper.getWritableDatabase();
return this;
}

public void close() {
mDbHelper.close();
}

我跑:

mDbHelper = new journalDbAdapter(this);
mDbHelper.open();

在我调用相机的 Activity 或类的 onCreate 中。我没有在 mDbHelper.close() 中编码;任何地方都不确定我是否应该在何时何地。我想我宁愿在拍摄一张图像时将其保持打开状态。

日志猫:

08-17 21:33:37.582: ERROR/Database(18297): java.lang.IllegalStateException: /data/data/com.growjournal.beta/databases/grower SQLiteDatabase created and never closed08-17 21:33:37.582: ERROR/Database(18297):     at android.database.sqlite.SQLiteDatabase.(SQLiteDatabase.java:1785)

如果这个问题从未得到解决,我可能会面临哪些问题?

一切似乎都工作正常,但我绝对希望避免在众多 Android 设备中出现任何问题。

最佳答案

您收到此错误是因为相机应用程序占用了大量内存,并且很可能导致您的应用程序关闭而不仅仅是暂停。您应该在 onPause 中保存记录并关闭数据库,然后在 onResume 和/或 onCreate 中重新打开它。

关于java - 拍照时数据库泄漏。 SQLiteDatabase 创建且从未关闭。安卓、Java、SQLite,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3508432/

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