0

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 で何も得られないため、例外はキャッチされません。

4

1 に答える 1

0
while(scanner.hasNext())

次のようにする必要があります。

while(scanner.hasNextLine())
于 2013-07-14T18:14:14.277 に答える