2014-11-27 2 views
0

초보자입니다. 답변을 명확하게 설명해주십시오. 감사합니다취소 버튼을 클릭하면 부울 값이 변경되지 않습니다 - AsyncTask - Android를 중지하는 방법?

편집 지금은 위의 코드 (편집 2) 발생 오류의

public class MainActivity extends Activity { 

     //other declarations 
     public ReadTask readTask; 
    protected void onCreate(Bundle savedInstanceState){ 
    readTask = new ReadTask(); 

    private OnClickListener test = new OnClickListener() 
     { 
      @Override 
      public void onClick (View V) 
      { 
       readTask.execute(); 
       //new ReadTask().execute(); 

      } 

    }; 
    private OnClickListener cancel = new OnClickListener() 
    { 
     @Override 
     public void onClick (View V) 
     { 
      readTask.cancel(true); 
      results1.setText(""); 
     } 

확인 EDIT 1이 2 ; 감사합니다.

나는 앱에 취소 버튼이 있습니다. 이를 클릭하면 이 발생합니다.

public void onClick (View V) 
     { 
        InputMethodManager inputManager = (InputMethodManager) 
        getSystemService(Context.INPUT_METHOD_SERVICE); 
      inputManager.hideSoftInputFromWindow(getCurrentFocus().getWindowToken(), 
         InputMethodManager.HIDE_NOT_ALWAYS); 

      new ReadTask().onCancelled(); 
      new ReadTask().cancel(true); 
      results1.setText("Cancelled"); 
     } 

ReadTask 이렇게 AsyncTask를 확장;

public class ReadTask extends AsyncTask<Void, String, Void> 
    { 
    BufferedReader reader = null; 
    public volatile boolean isCancelled=false; 
    //other declarations 
    protected void onCancelled() { 
     super.onCancelled(); 
     isCancelled = true; 
     new ReadTask().cancel(true); 
    } 

@Override 
    protected Void doInBackground(Void... params) 
    { 
      // isCancelled=false; 


     try { 
      for(int k=x1[3];k<=x2[3];k++) 
      { 
       //bunch of code 
      Log.w("5.newString", newString); 
      String isC1 = String.valueOf(isCancelled); 
      Log.w("5.Is cancelled?", isC1); // at this point, VALUE IS ALWAYS FALSE ! 

      if (isCancelled() || isCancelled == true) {Log.d("Entered","WHY");break;} 

       //bunch of code 

      } //bunch of catches 

여기에는 두 개의 메소드가 있는데, 하나는 부울 변수 isCancelled이고 다른 하나는 ReadTask()입니다. cancel (true); - 둘 다 작동하지 않아. 왜?

저는 신참이기 때문에 답변을 명확하게 설명하십시오. 감사합니다

************** EDIT 1 - 로그 캣 출력 *******

11-27 17:18:56.626: W/dalvikvm(28775): threadid=1: thread exiting with uncaught exception (group=0x41bcee48) 
11-27 17:18:56.636: E/AndroidRuntime(28775): FATAL EXCEPTION: main 
11-27 17:18:56.636: E/AndroidRuntime(28775): Process: com.example.pingtest, PID: 28775 
11-27 17:18:56.636: E/AndroidRuntime(28775): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.pingtest/com.example.pingtest.MainActivity}: java.lang.NullPointerException 
11-27 17:18:56.636: E/AndroidRuntime(28775): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2202) 
11-27 17:18:56.636: E/AndroidRuntime(28775): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2252) 
11-27 17:18:56.636: E/AndroidRuntime(28775): at android.app.ActivityThread.access$800(ActivityThread.java:139) 
11-27 17:18:56.636: E/AndroidRuntime(28775): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1200) 
11-27 17:18:56.636: E/AndroidRuntime(28775): at android.os.Handler.dispatchMessage(Handler.java:102) 
11-27 17:18:56.636: E/AndroidRuntime(28775): at android.os.Looper.loop(Looper.java:136) 
11-27 17:18:56.636: E/AndroidRuntime(28775): at android.app.ActivityThread.main(ActivityThread.java:5103) 
11-27 17:18:56.636: E/AndroidRuntime(28775): at java.lang.reflect.Method.invokeNative(Native Method) 
11-27 17:18:56.636: E/AndroidRuntime(28775): at java.lang.reflect.Method.invoke(Method.java:515) 
11-27 17:18:56.636: E/AndroidRuntime(28775): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:790) 
11-27 17:18:56.636: E/AndroidRuntime(28775): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:606) 
11-27 17:18:56.636: E/AndroidRuntime(28775): at dalvik.system.NativeStart.main(Native Method) 
11-27 17:18:56.636: E/AndroidRuntime(28775): Caused by: java.lang.NullPointerException 
11-27 17:18:56.636: E/AndroidRuntime(28775): at com.example.pingtest.MainActivity$ReadTask.<init>(MainActivity.java:120) 
11-27 17:18:56.636: E/AndroidRuntime(28775): at com.example.pingtest.MainActivity.onCreate(MainActivity.java:39) 
11-27 17:18:56.636: E/AndroidRuntime(28775): at android.app.Activity.performCreate(Activity.java:5275) 
11-27 17:18:56.636: E/AndroidRuntime(28775): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087) 
11-27 17:18:56.636: E/AndroidRuntime(28775): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2166) 
11-27 17:18:56.636: E/AndroidRuntime(28775): ... 11 more 
11-27 17:19:05.665: I/Process(28775): Sending signal. PID: 28775 SIG: 9 

+0

무엇을 하시겠습니까? – Broak

+0

또한 먼저 버튼을 테스트 해 보셨습니까? 취소 전화가 실행되고 있는지 확인하려면? – Broak

+0

버튼을 클릭 한 후 부울 값 (isCancelled)이 True로 변경되기를 원합니다. 코드의 주석도 읽어주십시오. 감사. – Zac1

답변

1

rt.cancel(true) 안녕 내가 설명과 코드에서 몇 가지 변화가 확인하시기 바랍니다 만들어 사용을 중지 활동의 모든 부분에 사용할 수 있습니다.

public class Asyn extends Activity { 

    public ReadTask readTask; 
    // keep global to prevent creating new async task on every time button click 
    boolean isCancelled = true; 
    TextView results1; 
    Button start, end; 

    protected void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 

     setContentView(R.layout.qww); 
     start = (Button) findViewById(R.id.button1); 
     end = (Button) findViewById(R.id.button2); 
     start.setOnClickListener(test); 
     end.setOnClickListener(cancel); 
     results1 = (TextView) findViewById(R.id.textView1); 
    } 

    private OnClickListener test = new OnClickListener() { 
     @Override 
     public void onClick(View V) { 
      if (isCancelled) { // checked to prevent creating new async task on 
           // every time button click 
       Toast.makeText(Asyn.this, "new task started", Toast.LENGTH_LONG) 
         .show(); 
       readTask = new ReadTask(); 
       readTask.execute(); 
       isCancelled = false; 
      } else { 
       Toast.makeText(Asyn.this, "Task already runing", 
         Toast.LENGTH_LONG).show(); 
      } 

     } 

    }; 
    private OnClickListener cancel = new OnClickListener() { 
     @Override 
     public void onClick(View V) { 
      if (null != readTask) { 
       Toast.makeText(Asyn.this, "Task stop", Toast.LENGTH_LONG) 
         .show(); 
       readTask.cancel(true); 
       isCancelled = true; 
      } 
      results1.setText(""); 
     } 
    }; 

     private class ReadTask extends AsyncTask<Void, String, Void> { 


    protected void onProgressUpdate(String... values) { 
     super.onProgressUpdate(values); 
     results1.setText(values[0].toString()); 


    } 
    @Override 
    protected Void doInBackground(Void... params) { 

     try { 
      for (int k = 0; k <= 10; k++) { 
       // bunch of code 
       Log.w("5.newString", k + ""); 
       String isC1 = String.valueOf(isCancelled); 
       Log.w("5.Is cancelled?", isC1); // at this point, VALUE IS 


        //below line for instant update as soon as the value is changed 
       publishProgress(" "+k + ""); 

       // use thread to see the update otherwise remove it 
        Thread.sleep(2000); 
       if (isCancelled() || isCancelled == true) { 
        Log.d("Entered", "WHY"); 
        break; 
       } 

       // bunch of code 

      } 
     } catch (Exception e) { 
      e.printStackTrace(); 
     } 
     return null; 

    } 

    @Override 
    protected void onPostExecute(Void result) { 
     // TODO Auto-generated method stub 
     super.onPostExecute(result); 
     // assign true to isCancelled so that user can start task again 
     isCancelled = true; 
    } 
} 
} 
+0

안녕하세요, 매번 "public ReadTask readTask;"라고 입력하면됩니다. MainActivty에서 앱이 시작되지 않습니다. 치명적 예외 : 주. 내가 주석을 달고 각 (테스트 및 취소 버튼)에 새로운 readTask를 인스턴스화하면 앱이 자동으로 실행됩니다. 실행됩니다. 이 클래스는 "ReadTask extends AsyncTask "클래스처럼 보입니다. 왜 이런 일이 일어 났는지 말해줘. 감사. – Zac1

+0

ReadTask 클래스는 내부 클래스이므로 private로 설정하십시오. 이미 편집했습니다. 모든 버튼을 클릭하거나 동일한 비동기 작업에서 새 작업을 만들지 여부를 설명 할 수 있습니다. 현재는 하나의 인스턴스 만 만듭니다. –

+0

비동기 작업이 1 개만 필요하며 취소 버튼을 누르면이 비동기 작업이 취소됩니다. 현재 취소는 작동하지만 doInBackground() 작업 내에서 현재 루프를 완료 한 후에 만 ​​작업을 취소합니다. 이 문제를 해결하는 방법? 감사. – Zac1

0

때마다 당신이 만드는 때문에 작동하지 않습니다 새 개체는 ReadTask입니다. 기존 작업을 취소하려는 경우 당신은이 작업을 수행해야합니다

public class MainActivity extends Activity { 
    ReadTask readTask; 

    @Override 
    public void onCreate (Bundle b) { 
     ... 
     readTask = new ReadTask(); 

     btnStart.setOnClickListener(new OnClickListener() { 
      @Override 
      void onClick(View v) { 
      readTask.execute(); 
      } 
     } 

     btnCancel.setOnClickListener(new OnClickListener() { 
      @Override 
      void onClick(View v) { 
      readTask.cancel(); 
      } 
     } 
    } 

} 
+0

그래, 나는 동의한다, 나는 그것을 처음으로 놓쳤다. – Broak

+0

아니요, ReadTask.execute()는 앱의 다른 버튼을 클릭하여 시작됩니다. 취소 버튼을 클릭하여 다른 스레드를 시작하고 싶지 않습니다. 나는 기존의 것을 멈추고 싶다. 이해하니? – Zac1

+0

그게 내가 말하는거야.클래스에있는 객체를 정의하고 취소 버튼의 onClick 메서드에서 해당 객체에 대해 cancel을 호출하고 새 객체를 만들지 마십시오. 내가 알 겠어? –

0
new ReadTask().onCancelled(); 
new ReadTask().cancel(true); 

코드의이 부분이 잘못 둘 다 ReadTask 클래스의 다른 인스턴스를 참조하십시오. 당신이 ReadTask 클래스

public ReadTask rt; 

의 전역 변수를 선언하고 onCreate() 방법에 그것을 초기화 할 수 있습니다.

rt = new ReadTask(); 

는 이미 rt.execute()를 사용하여 시작하고

+0

안녕하세요, 내가 해냈어, 내가이 일을한다면, 나는 NULL 포인터 예외와 응용 프로그램을 얻을. 시작되지 않습니다. – Zac1

+0

난 당신의 예제처럼, readTask = new ReadTask(); 번들 내에서 ReadTask readTask; MainActivity 내부. readTask.execute(); 첫 번째 버튼 안에는 readTask.cancel (true); CANCEL 버튼 안에 있습니다. 하지만 치명적인 예외 : 메인 (널 포인터 예외)가 발생하고 앱이 시작되지 않습니다. 왜? – Zac1

+0

전체 주요 활동 코드를 추가 할 수 있습니까? – MetaSnarf

관련 문제