今天在优化公司项目中,发现一个列表在离线加载时速度非常慢,加载1000条数据,竟然需要13s!!!
跟了一下db层代码
@Override
public ArrayList<Task> loadMineTask(String userId, boolean noblongs) {
.....//省略
Cursor cursor = db.rawQuery(sql, null);
while (cursor.moveToNext()) {
Task task = getFromCursor(cursor, false, false);
tasks.add(task);
}
cursor.close();
.....//省略
return tasks;
}
发现在执行rawQuery都是毫秒级,99%的时间集中在了getFromCursor(…)这个方法中了,继续跟踪:
private Task getFromCursor(Cursor cursor, boolean isLoadAllInfo,
boolean isLoadStages) {
.....//省略
String parentId = cursor.getString(cursor.getColumnIndex(FIELD_PARENT));
if (!TextUtils.isEmpty(parentId)) {
Task parentTask = loadTask(parentId)