我有这个代码:
DatabaseHandler db = new DatabaseHandler(this);
System.out.println("Start - " + System.currentTimeMillis());
for (int i = 1; i < db.getChampsCount() + 1; i++) {
String name = db.getChampInfo(i, "name");
String title = db.getChampInfo(i, "title");
String thumb = db.getChampInfo(i, "thumb");
System.out.println("End - " + System.currentTimeMillis());
[...]
}
还有这个
String getChampInfo(int id, String col) {
SQLiteDatabase db = this.getReadableDatabase();
Cursor cursor = db.rawQuery("SELECT " + col + " FROM champions WHERE id = " + id, new String[] {});
if (cursor != null)
cursor.moveToFirst();
db.close();
return cursor.getString(0);
}
这是 DatabaseHelper 类的一部分
它工作正常,但问题是执行时间太长(在我的安卓手机上为 2089 毫秒)。这些字符串是 UI 的一部分,所以我认为我不能把它放在另一个线程中。我该怎么做才能使这段代码运行得更快?
编辑:正好有 110 行