這麼多小時試圖弄清楚這一點,我已經閱讀了很多問題,論壇,答案..但它仍然不會更新用戶界面。AsyncTask更新UI
我的最終目標是從用戶那裏獲取一個搜索詞,然後發送一個httprequest到PHP腳本中,該腳本用JSON回覆。這工作正常,所以我不會深入研究它。
我的問題是在完成後更新UI。我可以得到HTTP結果,但現在,我只是試圖用一個基本的字符串更新UI,然後再實現諸如帶有監聽器的按鈕等所有結果的大變化。現在,只需添加簡單的String到UI。
onPreExecute()將一個字符串添加到用戶界面,並以某種方式正常工作,如下所示。
問題出在onPostExecute ..就像我說的,現在,只是一個字符串,測試(它將是一個列表或最終)。它根本不起作用,總是拋出異常。
public class DisplaySearchActivity extends ListActivity {
ArrayList<String> listItems=new ArrayList<String>();
ArrayAdapter<String> adapter = null;
private class updateUI extends AsyncTask<String, Void, String>{
@Override
protected void onPreExecute() {
listItems.add("Retrieving Results...");
// This actually works just like that
}
@Override
protected String doInBackground(String... message) {
final List<HashMap<String,String>> blist = httpSearch.search(message[0]);
return "It has done";
}
@Override
protected void onPostExecute(String b){
Log.v("ok", "shane - "+ b);
listItems.add("Business: "+ b);
adapter.notifyDataSetChanged();
}
}
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_display_search);
final ArrayAdapter<String> adapter = new ArrayAdapter<String>(this,android.R.layout.simple_list_item_1,listItems);
setListAdapter(adapter);
// final String message = getIntent().getStringExtra("input");
final String message = "third+level";
new updateUI().execute(message);
} // end onCreate
}
這裏是例外
03-15 13:38:41.190: V/ok(15732): shane - It has done
03-15 13:38:41.190: D/AndroidRuntime(15732): Shutting down VM
03-15 13:38:41.190: W/dalvikvm(15732): threadid=1: thread exiting with uncaught exception (group=0x4142a2a0)
03-15 13:38:41.200: E/AndroidRuntime(15732): FATAL EXCEPTION: main
03-15 13:38:41.200: E/AndroidRuntime(15732): java.lang.NullPointerException
03-15 13:38:41.200: E/AndroidRuntime(15732): at ie.whereis.DisplaySearchActivity$updateUI.onPostExecute(DisplaySearchActivity.java:34)
03-15 13:38:41.200: E/AndroidRuntime(15732): at ie.whereis.DisplaySearchActivity$updateUI.onPostExecute(DisplaySearchActivity.java:1)
03-15 13:38:41.200: E/AndroidRuntime(15732): at android.os.AsyncTask.finish(AsyncTask.java:631)
03-15 13:38:41.200: E/AndroidRuntime(15732): at android.os.AsyncTask.access$600(AsyncTask.java:177)
03-15 13:38:41.200: E/AndroidRuntime(15732): at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:644)
03-15 13:38:41.200: E/AndroidRuntime(15732): at android.os.Handler.dispatchMessage(Handler.java:99)
03-15 13:38:41.200: E/AndroidRuntime(15732): at android.os.Looper.loop(Looper.java:137)
03-15 13:38:41.200: E/AndroidRuntime(15732): at android.app.ActivityThread.main(ActivityThread.java:4898)
03-15 13:38:41.200: E/AndroidRuntime(15732): at java.lang.reflect.Method.invokeNative(Native Method)
03-15 13:38:41.200: E/AndroidRuntime(15732): at java.lang.reflect.Method.invoke(Method.java:511)
03-15 13:38:41.200: E/AndroidRuntime(15732): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1006)
03-15 13:38:41.200: E/AndroidRuntime(15732): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:773)
03-15 13:38:41.200: E/AndroidRuntime(15732): at dalvik.system.NativeStart.main(Native Method)
我認爲這是由行拋出:
adapter.notifyDataSetChanged();
但我就是不真正瞭解適配器做什麼,即使經過很多閱讀。我不知道爲什麼在執行工作:S,但後在一個不是爲什麼
。
任何幫助非常感謝。
謝謝,我已經評論瞭解決方案。抱歉無法完成投票。的< 15因果報應
我適配器實例化兩次,似乎是這個問題,並在去除最終ArrayAdapter的建議,這個問題已經解決assing .. 謝謝你漂亮的腦袋有! –
shanehoban
2013-03-15 13:55:53