Я создаю приложение, использующее AsyncTask, и я хочу, чтобы оно использовало два потока, один из которых является классом asyncTask, а другой - классом потока (он находится в asyncTask), а второй поток работает, когда я нажимаю кнопку запуска. Я хочу, чтобы они работали вместе. Я запустил приложение, и поток asyncTask работает нормально, но когда я нажимаю кнопку, чтобы запустить второй поток, который находится в потоке synckTask, к сожалению, приложение остановилось. вот код:

public class MainActivity extends Activity {

private Thread thread;
private Button btnStart;
private TextView textView;
private Async a;
int i=0;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    textView=(TextView)findViewById(R.id.textEdit);
    btnStart=(Button)findViewById(R.id.btnStart);
    btnStart.setOnClickListener(onStart);

    a=new Async();
    a.execute();
}

@Override
public boolean onCreateOptionsMenu(Menu menu) {
    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.main, menu);
    return true;
}

public class Async extends AsyncTask< String, Long , Void >{

    @Override
    protected void onPreExecute() {
        textView.setText("has started ... ");
        super.onPreExecute();
    }

    @Override
    protected void onProgressUpdate(Long... values) {

        thread=new Thread(){
            @Override
            public void run() {
                while(i<6) {
                    runOnUiThread(new Runnable() {
                        @Override
                        public void run() {
                            textView.setText(String.valueOf(i));
                            Log.w(" onPostExecute ", String.valueOf(i));
                            i++;
                        }
                    });

                    try {
                        Thread.sleep(1000);
                    } catch (InterruptedException e) {
                        // TODO Auto-generated catch block
                        e.printStackTrace();
                    }
                }
                super.run();
            }
        };

        super.onProgressUpdate(values);
    }

    @Override
    protected Void doInBackground(String... params) {
        for (int i = 0; i < 12 ; i++) {
            try {
                Thread.sleep(200);
            } catch (InterruptedException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
            Log.i("count index in background ", String.valueOf(i));         
        }

        return null;
    }


    @Override
    protected void onPostExecute(Void result) {

    }
}

private View.OnClickListener onStart=new View.OnClickListener(){

    @Override
    public void onClick(View v) {
        thread.start();

    }

};

}

Пожалуйста, посоветуйте мне, как я могу исправить это, чтобы он работал нормально ...

Большое спасибо...

И вот его лог:

03-17 07:35:35.913: D/libEGL(1113): loaded /system/lib/egl/libEGL_emulation.so

03-17 07: 35: 35.943: D / (1113): HostConnection :: get () Установлено новое соединение с хостом 0x2a154d20, tid 1113

03-17 07: 35: 35.963: D / libEGL (1113): загружено /system/lib/egl/libGLESv1_CM_emulation.so

03-17 07: 35: 35.963: D / libEGL (1113): загружено /system/lib/egl/libGLESv2_emulation.so

03-17 07: 35: 36.133: W / EGL_emulation (1113): eglSurfaceAttrib не реализовано

03-17 07: 35: 36.133: Индекс I / count в фоновом режиме (1113): 0

03-17 07: 35: 36.144: D / OpenGLRenderer (1113): Включение режима отладки 0

03-17 07: 35: 36.404: Индекс I / count в фоновом режиме (1113): 1

03-17 07: 35: 36.661: Индекс I / count в фоновом режиме (1113): 2

03-17 07: 35: 36.865: Индекс I / count в фоновом режиме (1113): 3

03-17 07: 35: 37.068: Индекс I / count в фоновом режиме (1113): 4

03-17 07: 35: 37.272: Индекс I / count в фоновом режиме (1113): 5

03-17 07: 35: 37.480: Индекс I / count в фоновом режиме (1113): 6

03-17 07: 35: 37.683: Индекс I / count в фоновом режиме (1113): 7

03-17 07: 35: 37.891: Индекс I / count в фоновом режиме (1113): 8

03-17 07: 35: 38.223: Индекс I / count в фоновом режиме (1113): 9

03-17 07: 35: 38.631: Индекс I / count в фоновом режиме (1113): 10

03-17 07: 35: 38.837: Индекс I / count в фоновом режиме (1113): 11

03-17 07: 35: 41.403: D / AndroidRuntime (1113): Завершение работы ВМ

03-17 07: 35: 41.403: W / dalvikvm (1113): threadid = 1: поток завершается с неперехваченным исключением (группа = 0x40a71930)

03-17 07: 35: 41.443: E / AndroidRuntime (1113): FATAL EXCEPTION: main

03-17 07: 35: 41.443: E / AndroidRuntime (1113): java.lang.NullPointerException

03-17 07: 35: 41.443: E / AndroidRuntime (1113): в com.example.asynctasckdemo.MainActivity $ 1.onClick (MainActivity.java:104)

03-17 07: 35: 41.443: E / AndroidRuntime (1113): в android.view.View.performClick (View.java:4204)

03-17 07: 35: 41.443: E / AndroidRuntime (1113): в android.view.View $ PerformClick.run (View.java:17355)

03-17 07: 35: 41.443: E / AndroidRuntime (1113): на android.os.Handler.handleCallback (Handler.java:725)

03-17 07: 35: 41.443: E / AndroidRuntime (1113): в android.os.Handler.dispatchMessage (Handler.java:92)

03-17 07: 35: 41.443: E / AndroidRuntime (1113): на android.os.Looper.loop (Looper.java:137)

03-17 07: 35: 41.443: E / AndroidRuntime (1113): в android.app.ActivityThread.main (ActivityThread.java:5041)

03-17 07: 35: 41.443: E / AndroidRuntime (1113): в java.lang.reflect.Method.invokeNative (собственный метод)

03-17 07: 35: 41.443: E / AndroidRuntime (1113): в java.lang.reflect.Method.invoke (Method.java:511)

03-17 07: 35: 41.443: E / AndroidRuntime (1113): в com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run (ZygoteInit.java:793)

03-17 07: 35: 41.443: E / AndroidRuntime (1113): на com.android.internal.os.ZygoteInit.main (ZygoteInit.java:560)

03-17 07: 35: 41.443: E / AndroidRuntime (1113): в dalvik.system.NativeStart.main (собственный метод)

0
poursina 17 Мар 2014 в 11:45
1
Можете ли вы поделиться ошибкой журнала, когда приложение останавливается?
 – 
Neonamu
17 Мар 2014 в 11:49
Майк М, спасибо за ответ. Я использовал onProgressUpdate (), но он не работает. Я хочу, чтобы они оба работали вместе.
 – 
poursina
17 Мар 2014 в 12:03
1
Метод onProgressUpdate никогда не вызывается. Вы должны вызвать его вручную с помощью publishProgress: developer.android.com/reference/android/os/… И поскольку он никогда не запускается, thread не имеет значения (и имеет значение NULL)
 – 
Jave
17 Мар 2014 в 12:09

1 ответ

Лучший ответ
@Override
protected Void doInBackground(String... params) {
    for (int i = 0; i < 12 ; i++) {
        try {
            Thread.sleep(200);
            publishProgress();//try calling this<------------------------------
        } catch (InterruptedException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        Log.i("count index in background ", String.valueOf(i));         
    }

    return null;
}
1
vipul mittal 17 Мар 2014 в 12:23