我在我的 Android 程序中显示一个 ListView,使用 ArrayAdapter 从字符串数组中获取数据。通常,我从 InputStream 获取数据以填充字符串数组,并且 ListView 正确显示。但是,如果我的 InputStream 为空,我将使用字符串值初始化我的数组。发生这种情况时,我在将 arrayadapter 应用到我的列表视图时会收到 NullPointException。
这是我初始化字符串数组的方法。
protected String[] doInBackground(Void...parameters ) {
......... do something
String[] result = new String[50];
result[0] = "No restaurants found in this area";
....... get my httpconnection
这就是我填充字符串数组的方式:
........
if(responseCode == HttpURLConnection.HTTP_OK) {
InputStream in = httpConnection.getInputStream();
BufferedReader br = new BufferedReader(
new InputStreamReader(in));
String line;
int x=0;
while ((line = br.readLine()) != null) {
result[x] = line;
x++;
}
return result;
}
这是我创建列表视图的地方:
protected void onPostExecute(String[] result) {
ListView restaurant_list = (ListView) findViewById(R.id.restaurant_list);
final ArrayAdapter<String> arrayAdpt = new ArrayAdapter<String>(getApplicationContext(), R.layout.listview, R.id.viewtext, result);
restaurant_list.setAdapter(arrayAdpt);
}
如果我从输入流中获取数据,一切正常。如果我没有得到任何数据,则字符串数组仅包含我的初始化值和 list.setAdapter(arrayAdpt) 行(最后一行)的程序炸弹。此外,此处理是在 doInBackground 方法下的异步任务 (AsynTask) 下完成的。为什么我在字符串数组中的数据源会对 arrayadapter 的工作方式产生影响?有人有建议吗?
好的。我改变了我的逻辑来使用
List<String> result = new ArrayList<String>();
.....
result.add(line);
.....
return (String[]) result.toArray();
它给了我一个空异常,我会在返回指令中假设,因为错误在 doInBackground 方法中。以下是来自 logcat 的错误。
03-09 20:03:13.755: E/AndroidRuntime(6089): FATAL EXCEPTION: AsyncTask #1
03-09 20:03:13.755: E/AndroidRuntime(6089): java.lang.RuntimeException: An error occured while executing doInBackground()
03-09 20:03:13.755: E/AndroidRuntime(6089): at android.os.AsyncTask$3.done(AsyncTask.java:299)
03-09 20:03:13.755: E/AndroidRuntime(6089): at java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:352)
03-09 20:03:13.755: E/AndroidRuntime(6089): at java.util.concurrent.FutureTask.setException(FutureTask.java:219)
03-09 20:03:13.755: E/AndroidRuntime(6089): at java.util.concurrent.FutureTask.run(FutureTask.java:239)
03-09 20:03:13.755: E/AndroidRuntime(6089): at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:230)
03-09 20:03:13.755: E/AndroidRuntime(6089): at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1080)
03-09 20:03:13.755: E/AndroidRuntime(6089): at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:573)
03-09 20:03:13.755: E/AndroidRuntime(6089): at java.lang.Thread.run(Thread.java:856)
03-09 20:03:13.755: E/AndroidRuntime(6089): Caused by: java.lang.ClassCastException: java.lang.Object[] cannot be cast to java.lang.String[]
03-09 20:03:13.755: E/AndroidRuntime(6089): at com.example.herb4.MainActivity$GetRestaurant.doInBackground(MainActivity.java:173)
03-09 20:03:13.755: E/AndroidRuntime(6089): at com.example.herb4.MainActivity$GetRestaurant.doInBackground(MainActivity.java:1)
03-09 20:03:13.755: E/AndroidRuntime(6089): at android.os.AsyncTask$2.call(AsyncTask.java:287)
03-09 20:03:13.755: E/AndroidRuntime(6089): at java.util.concurrent.FutureTask.run(FutureTask.java:234)