我正在构建一个应用程序,该应用程序在WebView中显示一些远程数据,这些数据被缓存在SQLite数据库中。JavaScript函数通过JavaScript接口从WebView请求数据。
当用户在页面上的输入元素中输入时,JavaScript函数通过调用Java函数请求搜索结果,Java函数再触发SQL查询。然后将结果以适当的JSON格式打包并返回。
获取数据工作正常,除非您输入得非常快。如果您打字足够快,在按下几个键后,该应用程序会退出而无需抛出任何异常,它只会回到主屏幕。
我已经成功地缩小了原因 - 注释掉对.query方法的调用可以防止崩溃,但使应用程序无用。 有没有办法检查是什么导致应用程序退出,还有其他日志或工具可以帮助? Java函数代码:
更新:
我发现可以通过发出命令来访问另一个日志。
当应用程序崩溃时,只有一个条目。
当用户在页面上的输入元素中输入时,JavaScript函数通过调用Java函数请求搜索结果,Java函数再触发SQL查询。然后将结果以适当的JSON格式打包并返回。
获取数据工作正常,除非您输入得非常快。如果您打字足够快,在按下几个键后,该应用程序会退出而无需抛出任何异常,它只会回到主屏幕。
我已经成功地缩小了原因 - 注释掉对.query方法的调用可以防止崩溃,但使应用程序无用。 有没有办法检查是什么导致应用程序退出,还有其他日志或工具可以帮助? Java函数代码:
public Lot[] getLotList(String query, int limitCount) {
...
...
String[] resultColumns = new String[] { LotsSearch._ID };
String queryWhere = LotsSearch.TABLE_NAME + " MATCH ?";
String[] queryArgs = new String[] { query + "*" };
String sortOrder = LotsSearch.COLUMN_NAME_NUMBER + " ASC, " + LotsSearch.COLUMN_NAME_TITLE + " ASC";
String limit = null;
Cursor cursor = null;
if (limitCount != -1)
limit = "0," + limitCount;
try {
cursor = mDb.query(LotsSearch.TABLE_NAME, resultColumns, queryWhere, queryArgs, null, null, sortOrder, limit);
if (cursor != null && cursor.moveToFirst()) {
result = new Lot[cursor.getCount()];
try {
int idColumnIndex = cursor.getColumnIndexOrThrow(LotsSearch._ID);
int lotId;
Lot lot;
do {
lotId = cursor.getInt(idColumnIndex);
lot = mLots.get(lotId);
if (lot != null)
result[index++] = lot;
} while (cursor.moveToNext());
} catch (IllegalArgumentException e) {
e.printStackTrace();
}
}
} catch (SQLiteException e) {
e.printStackTrace();
} finally {
if (cursor != null)
cursor.close();
}
...
...
return result;
}
更新:
我发现可以通过发出命令来访问另一个日志。
logcat -b events
当应用程序崩溃时,只有一个条目。
I/am_proc_died( 59): [11473,com.example.app]
当应用程序正常退出时,此日志会显示一组条目:
I/am_finish_activity( 59): [1157978656,22,com.example.app/.MainActivity,app-request]
I/am_pause_activity( 59): [1157978656,com.example.app/.MainActivity]
I/am_on_paused_called(11473): com.example.app.MainActivity
I/am_destroy_activity( 59): [1157978656,22,com.example.app/.MainActivity]