具有异步任务的多线程

时间:2014-03-17 07:45:49

标签: android multithreading

我正在创建一个使用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 index in background(1113):0

03-17 07:35:36.144:D / OpenGLRenderer(1113):启用调试模式0

03-17 07:35:36.404:我/背景中的计数指数(1113):1

03-17 07:35:36.661:我/背景中的计数指数(1113):2

03-17 07:35:36.865:我/背景中的计数指数(1113):3

03-17 07:35:37.068:我/背景中的计数指数(1113):4

03-17 07:35:37.272:我/背景中的计数指数(1113):5

03-17 07:35:37.480:我/背景中的计数指数(1113):6

03-17 07:35:37.683:我/背景中的计数指数(1113):7

03-17 07:35:37.891:我/背景中的计数指数(1113):8

03-17 07:35:38.223:I / count index in background(1113):9

03-17 07:35:38.631:我/背景中的计数指数(1113):10

03-17 07:35:38.837:我/背景中的计数指数(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):致命异常:主

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

03-17 07:35:41.443:E / AndroidRuntime(1113):at 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):at java.lang.reflect.Method.invokeNative(Native Method)

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

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

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

03-17 07:35:41.443:E / AndroidRuntime(1113):at dalvik.system.NativeStart.main(Native Method)

1 个答案:

答案 0 :(得分: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;
}