1
我有兩個相互競爭的問題。使用AsyncTask進行Android ListView過濾
形勢
明白了我試圖通過對變化的EditText
來篩選海量列表視圖10K +項目。
錯誤1
ANR keyDispatchingTimedOut error
我有UI線程(縫在合理的時間)的過濾操作,我認爲是什麼原因造成在某些手機上的錯誤.. 。
爲錯誤1
試圖修復創建一個AsyncTask
特別對於C阿靈我的過濾功能...
/// <summary>
/// Implementation of Android AsyncTask to perform the StudentFiltering in background
/// </summary>
internal class FilterStudentsTask : AsyncTask
{
private Student[] _students;
private StudentList _outer;
private StudentListAdapter _adapter;
private string _filterText;
public FilterStudentsTask(StudentList outer, StudentListAdapter adapter, string filterText)
{
this._outer = outer;
this._adapter = adapter;
this._filterText = filterText;
}
protected override Java.Lang.Object DoInBackground(params Java.Lang.Object[] @params)
{
// filter the list
this._adapter.filterStudents(this._filterText);
return true;
}
protected override void OnPostExecute(Java.Lang.Object result)
{
// Notify adapter of Data Change (to trigger re-draw)
this._adapter.NotifyDataSetChanged();
base.OnPostExecute(result);
}
}
錯誤2
所以,現在,因爲我已經有了另一個線程採取過濾的照顧,它不告訴我,我不應該用後臺線程此操作類型,它應該只發生在UI線程上。
E/AndroidRuntime(9738): FATAL EXCEPTION: main
E/AndroidRuntime(9738): java.lang.IllegalStateException: The content of the adapter has changed but ListView did not receive a notification. Make sur
e the content of your adapter is not modified from a background thread, but only from the UI thread. [in ListView(2131361885, class mapdroid.ColorFade
ListView) with Adapter(class mapdroid.StudentList_StudentListAdapter)]
E/AndroidRuntime(9738): at android.widget.ListView.layoutChildren(ListView.java:1510)
E/AndroidRuntime(9738): at android.widget.AbsListView.onLayout(AbsListView.java:1260)
E/AndroidRuntime(9738): at android.view.View.layout(View.java:7175)
E/AndroidRuntime(9738): at android.widget.RelativeLayout.onLayout(RelativeLayout.java:912)
E/AndroidRuntime(9738): at android.view.View.layout(View.java:7175)
E/AndroidRuntime(9738): at android.widget.FrameLayout.onLayout(FrameLayout.java:338)
E/AndroidRuntime(9738): at android.view.View.layout(View.java:7175)
E/AndroidRuntime(9738): at android.widget.FrameLayout.onLayout(FrameLayout.java:338)
E/AndroidRuntime(9738): at android.view.View.layout(View.java:7175)
E/AndroidRuntime(9738): at android.view.ViewRoot.performTraversals(ViewRoot.java:1140)
E/AndroidRuntime(9738): at android.view.ViewRoot.handleMessage(ViewRoot.java:1859)
E/AndroidRuntime(9738): at android.os.Handler.dispatchMessage(Handler.java:99)
E/AndroidRuntime(9738): at android.os.Looper.loop(Looper.java:130)
E/AndroidRuntime(9738): at android.app.ActivityThread.main(ActivityThread.java:3683)
E/AndroidRuntime(9738): at java.lang.reflect.Method.invokeNative(Native Method)
E/AndroidRuntime(9738): at java.lang.reflect.Method.invoke(Method.java:507)
E/AndroidRuntime(9738): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
E/AndroidRuntime(9738): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
E/AndroidRuntime(9738): at dalvik.system.NativeStart.main(Native Method)
W/ActivityManager( 111): Force finishing activity MapDroid.MapDroid/mapdroid.StudentList
W/ActivityManager( 111): Activity pause timeout for HistoryRecord{40670aa0 MapDroid.MapDroid/mapdroid.StudentList}
我錯過了一些東西,但是做了這些錯誤似乎有衝突嗎?你如何協調它們?
您是否考慮讓XML解析器將數據插入SQLite數據庫,然後使用'CursorAdapter'將它綁定到您的'ListView'?這會給你更清潔的代碼,沒有線程問題和更好的性能。 –