2013-04-02 4 views
0

- 비동기 작업 메서드를 사용하여 웹 서비스에 접근하려고했습니다.for 루프의 비동기 작업 진행률 표시 줄

- 여기서는 for 루프가 첫 번째 대화 상자에서 진행률 대화 상자를 닫고 응용 프로그램을 중단합니다. 이 코드를 잘 확인하고 제안하십시오.

코드

for(Pageview pg:views) 
{ 
value1=url1+"userid="+pg.getuserid()+"&chapterid="+pg.getchapterid()+"&pageno="+pg.getpageno()+"&view%20time="+pg.getviewtime()+"&IMEI%20no="+pg.getimeino()+"&feedback="+pg.getfeedback()+"&Comments="+pg.getcomments(); 
//Toast.makeText(getApplicationContext(), value1, Toast.LENGTH_LONG).show(); 
System.out.println(value1); 
// feedbackdata feedback1=new feedbackdata(); 
feedbak.execute(value1); 
    feedbackdata.loadingProgress = GUIStaticMethod.returnProgressBar(getApplicationContext()); 

     //myLoginDataFatcher.start(); 

GUIStaticMethod.mProgressDialog.setOnDismissListener(new OnDismissListener() { 

    public void onDismiss(DialogInterface dialog) { 



     if(res1.contains("Page View Insertion Successfully")==true) 
     { 
      Toast.makeText(getApplicationContext(), res1, Toast.LENGTH_LONG).show(); 

     } 
     else if(res1.contains("Page View Insertion Failed")==true) 
     { 

     } 
    } 


}); 

ERROR

04-02 10:52:34.956: E/AndroidRuntime(234): Uncaught handler: thread main exiting due to uncaught exception 
04-02 10:52:34.976: E/AndroidRuntime(234): java.lang.IllegalStateException: Cannot execute task: the task has already been executed (a task can be executed only once) 
04-02 10:52:34.976: E/AndroidRuntime(234): at android.os.AsyncTask.execute(AsyncTask.java:383) 
04-02 10:52:34.976: E/AndroidRuntime(234): at com.example.wireframe.webviewurl$11.onDismiss(webviewurl.java:1751) 
04-02 10:52:34.976: E/AndroidRuntime(234): at android.app.Dialog$ListenersHandler.handleMessage(Dialog.java:1058) 
04-02 10:52:34.976: E/AndroidRuntime(234): at android.os.Handler.dispatchMessage(Handler.java:99) 
04-02 10:52:34.976: E/AndroidRuntime(234): at android.os.Looper.loop(Looper.java:123) 
04-02 10:52:34.976: E/AndroidRuntime(234): at android.app.ActivityThread.main(ActivityThread.java:4363) 
04-02 10:52:34.976: E/AndroidRuntime(234): at java.lang.reflect.Method.invokeNative(Native Method) 
04-02 10:52:34.976: E/AndroidRuntime(234): at java.lang.reflect.Method.invoke(Method.java:521) 
04-02 10:52:34.976: E/AndroidRuntime(234): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860) 
04-02 10:52:34.976: E/AndroidRuntime(234): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618) 
04-02 10:52:34.976: E/AndroidRuntime(234): at dalvik.system.NativeStart.main(Native Method) 
+1

@Lucifer 당신은 글을 편집했는데, 왜 당신은 가독성을 높이기 위해 들여 쓰기를 제공하지 않았습니까? –

+0

StackTrace에서 AsyncTask가'onDismiss (...)'메소드에서 실행되고 있지만 코드에서 볼 수 없다는 것을 알았습니다. –

+1

@ClassStacker, 상태 완료 :) – Lucifer

답변

0

예외가 제안 당신은 같은 AsyncTask를 여러 시간을 실행할 수 없습니다. 루프 언더 피드백 객체를 초기화하고 태스크 (a 초 실행이 시도 될 경우, 예외가 발생한다.)

한번만 실행될 수

AsyncTask를 스레딩 규칙에 따라

실행할

0

그것은 말합니다 : Cannot execute task: the task has already been executed (a task can be executed only once). 즉, AsyncTask를 만들고 을 한 번 실행하고 가비지 수집하도록하십시오. 동일한 인스턴스에 대해 execute() 번을 두 번 이상 호출 할 수 없습니다.

2

모든 반복마다 AsyncTask 인스턴스를 새로 만듭니다.

new AsyncTask().execute(value); 

스레드가 run() 방법으로 수행되면, 다시 시작할 수 없기 때문에 당신이 다시 스레드를 실행할 수없는 존재 이유. 그래서 다시 시작하려고하면 IllegalStateException이 표시됩니다.