- 비동기 작업 메서드를 사용하여 웹 서비스에 접근하려고했습니다.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)
@Lucifer 당신은 글을 편집했는데, 왜 당신은 가독성을 높이기 위해 들여 쓰기를 제공하지 않았습니까? –
StackTrace에서 AsyncTask가'onDismiss (...)'메소드에서 실행되고 있지만 코드에서 볼 수 없다는 것을 알았습니다. –
@ClassStacker, 상태 완료 :) – Lucifer