OutOfMemoryError : no stack available

OutOfMemoryError : no stack available

我使用 SQLite 数据库在我的应用程序中存储数据。这是我如何在异步任务上访问数据的示例:

ArrayList < Data > allMessages = new ArrayList<>();
String query = "SELECT * FROM ..........";
SQLiteDatabase db = this.getWritableDatabase();
Cursor c = db.rawQuery(query, new String[]{username});
try {
    if (c.moveToFirst()) {
        do {
            Data data = new Data(c.getString(0),.....)
            allMessages.add(data);
        } while (c.moveToFirst());
    }
} finally {
    c.close();
}

在运行时,我得到这个异常:

java.lang.RuntimeException: An error occured while executing doInBackground()
        at android.os.AsyncTask.done(AsyncTask.java:304)
        at java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:355)
        at java.util.concurrent.FutureTask.setException(FutureTask.java:222)
        at java.util.concurrent.FutureTask.run(FutureTask.java:242)
        at android.os.AsyncTask$SerialExecutor.run(AsyncTask.java:231)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
        at java.lang.Thread.run(Thread.java:818)
 Caused by: java.lang.OutOfMemoryError: OutOfMemoryError thrown while trying to throw OutOfMemoryError; no stack available

目前,我的数据库包含大约 20 条记录,我相信这不足以导致内存溢出...

感谢阅读。

你的问题是你只曾经读过第一条记录,因为你使用

} while (c.moveToFirst());

这只会读取第一条记录,您的 ArrayList 将填满第一条记录的数百万份副本。您最终会收到 OutOfMemory 错误。


改为使用

} while (c.moveToNext());

这将正确读取所有记录。