这么多小时试图弄清楚这一点,我已经阅读了很多问题、论坛、答案..但它仍然不会更新 UI。
我的最终目标是从用户那里获取一个搜索词,然后向 PHP 脚本发送一个 httprequest,该脚本以 JSON 进行回复。这很好用,所以我不会深入研究它。
完成后我的问题是更新 UI。我可以获得 HTTP 结果,但现在,我只是尝试在实现重大更改之前使用基本字符串更新 UI,例如带有侦听器的按钮等所有结果。现在,只是简单的字符串添加到 UI。
onPreExecute() 向 UI 添加了一个字符串,这在某种程度上可以正常工作,如下所示。
问题出在 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();
但我只是不明白适配器的作用,即使经过大量阅读。我不知道为什么
listItems.add("Retrieving Results...");
在 pre Execute 作品中:S 但在 post 中没有。
非常感谢任何帮助。
谢谢,我已经评论了解决方案。为无法投票而道歉。<15 业力