2014-02-19 136 views
1

我在爲新應用程序做一些測試時遇到問題。 我有一個活動,我執行一個asynctask與我的服務器通信並要求提供一個json文件。從處理程序調用asynctask android

我想這個文件是定期下載的(不知道,3-4秒),所以我在我的活動中創建了一個處理程序,每次都執行它。

它工作正常使用日誌,但每當我試圖執行的AsyncTask,它使一個例外,俗話說:

02-19 10:16:41.510: WARN/System.err(9051): java.lang.IllegalStateException: Cannot execute task: the task is already running. 
02-19 10:16:41.510: WARN/System.err(9051): at android.os.AsyncTask.executeOnExecutor(AsyncTask.java:576) 
02-19 10:16:41.510: WARN/System.err(9051): at android.os.AsyncTask.execute(AsyncTask.java:535) 
02-19 10:16:41.510: WARN/System.err(9051): at com.mobile.myPacket.mySecondActivity.askForData(mySecondActivity.java:68) 
02-19 10:16:41.510: WARN/System.err(9051): at com.mobile.myPacket.mySecondActivity.access$000(mySecondActivity.java:22) 
02-19 10:16:41.510: WARN/System.err(9051): at com.mobile.myPacket.mySecondActivity$1.run(mySecondActivity.java:56) 
02-19 10:16:41.510: WARN/System.err(9051): at android.os.Handler.handleCallback(Handler.java:733) 
02-19 10:16:41.510: WARN/System.err(9051): at android.os.Handler.dispatchMessage(Handler.java:95) 
02-19 10:16:41.510: WARN/System.err(9051): at android.os.Looper.loop(Looper.java:136) 
02-19 10:16:41.510: WARN/System.err(9051): at android.app.ActivityThread.main(ActivityThread.java:5017) 
02-19 10:16:41.510: WARN/System.err(9051): at java.lang.reflect.Method.invokeNative(Native Method) 
02-19 10:16:41.510: WARN/System.err(9051): at java.lang.reflect.Method.invoke(Method.java:515) 
02-19 10:16:41.510: WARN/System.err(9051): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779) 
02-19 10:16:41.510: WARN/System.err(9051): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595) 
02-19 10:16:41.510: WARN/System.err(9051): at dalvik.system.NativeStart.main(Native Method)  

我想這是因爲它是另一個線程,第二次呼叫正在與第一個問題。但我不知道如何解決它。

這是我的活動:

  package com.mobile.myPacket; 

      import android.app.Activity; 
      import android.os.Bundle; 
      import android.os.Handler; 
      import android.util.Log; 
      import android.view.LayoutInflater; 
      import android.view.View; 
      import android.view.ViewGroup; 
      import com.mobile.clases.AsyncResponse; 
      import com.mobile.clases.MyTask; 


      import android.os.Bundle; 
      import android.view.LayoutInflater; 
      import android.view.View; 
      import android.view.ViewGroup; 
      import org.json.JSONArray; 
      import org.json.JSONException; 
      import org.json.JSONObject; 

      public class SecondActivity extends Activity implements AsyncResponse { 

       private String urlServer = "url"; 
       MyTask asyncTask =new MyTask(); 
       Handler handler = new Handler(); 


       public void onCreate(Bundle savedInstanceState) { 
        super.onCreate(savedInstanceState); 
        handler.post(sendData); 
        setContentView(R.layout.secondActivity); 
        asyncTask.delegate = this; 
        //We ask for data the first time 
        askForData(); 
       } 


       @Override 
       public void processFinish(JSONArray output) { //Executed from asyncTask 
        //Data received 
        Log.i("TEST", output.toString()); 
       } 

       @Override 
       protected void onDestroy() { 
        super.onDestroy(); 
        handler.removeCallbacks(sendData); 
       } 

       private final Runnable sendData = new Runnable(){ 
        public void run(){ 
         try { 
          //prepare and send the data here.. 

          askForData(); 
          //Log.i("TEST","aa"); 
            handler.postDelayed(this, 3000); 
         } 
         catch (Exception e) { 
          e.printStackTrace(); 
         } 
        } 
       }; 

       private void askForData(){ 
        Log.i("TEST","askForData"); 
        asyncTask.execute(urlServer+"test.php"); 
       } 


      } 

沒有處理程序,的AsyncTask工作正常,只是一個時間。所以我猜這個課是好的。

回答

2

您不能多次執行相同的AsyncTask

之前執行AsyncTask,首先實例化一個新的實例:

private void askForData(){ 
    asyncTask = new MyTask(); 
    asyncTask.delegate = this; 
    asyncTask.execute(urlServer+"test.php"); 
} 

此外,在你的類的開頭刪除AsyncTask的實例。

+0

你是男人。有用。我在想這件事。 – Biribu

0

嘗試這樣,

private void askForData(){ 

if (task.getStatus() == AsyncTask.Status.FINISHED) { 
    task = new AsyncTask(); 
} 

if (task.getStatus() != AsyncTask.Status.RUNNING) { 
    task.execute(); 
} 
} 
相關問題