AsyncTask を拡張する FetchTaskList という UI スレッド内にクラスを作成しました。サーバーソケットを使用しており、ソケットの入力ストリームから読み取ろうとしています。デバッグ時、doInBackground は while ループが終了した後に停止するため、onPostExecute は呼び出されません。なぜこうなった?私はこれについて何日も頭を悩ませてきました...
TaskListActivity.java
private class FetchTaskList extends AsyncTask<Void, Void, JSONArray> {
@Override
protected JSONArray doInBackground(Void... params)
{
JSONArray jArray = new JSONArray();
try
{
socket = new Socket(DEFAULT_HOST, DEFAULT_PORT);
Scanner scanner = new Scanner(socket.getInputStream());
PrintStream out = new PrintStream(socket.getOutputStream());
while(scanner.hasNext())
{
JSONObject json = new JSONObject(scanner.nextLine());
jArray.put(json);
}
return jArray;
}
catch (UnknownHostException e)
{
e.printStackTrace();
Log.e("YOUR_APP_LOG_TAG", "I got an error", e);
} catch (IOException e)
{
e.printStackTrace();
Log.e("YOUR_APP_LOG_TAG", "I got an error", e);
}
catch (JSONException e)
{
e.printStackTrace();
Log.e("YOUR_APP_LOG_TAG", "I got an error", e);
}
return jArray;
}
@Override
protected void onPostExecute(JSONArray list)
{
for (int i = 0; i < list.length(); i++)
{
try
{
JSONObject obj = new JSONObject();
obj = list.getJSONObject(i);
taskList.add(new Task(obj.get("author").toString(),obj.get("description").toString(),(Date)obj.get("due"),(Task.Priority)obj.get("priority"),(Task.Status)obj.get("status")));
}
catch(Exception e)
{
Log.e("YOUR_APP_LOG_TAG", "I got an error", e);
}
}
ListView view = (ListView) findViewById(R.id.taskListView);
TaskListAdapter theAdapter = new TaskListAdapter(taskList,getApplicationContext());
view.setAdapter(theAdapter);
view.invalidate();
}
}
編集: LogCat で何も得られないため、例外はキャッチされません。