UI线程与其他线程之间使用处理程序进行通信

时间:2017-02-27 00:02:29

标签: java android multithreading runnable httpconnection

如何在UI线程和后台线程之间进行线程间通信?我想在这里使用通用处理程序概念来更新我的UI。 我有以下概念

new Thread(new Runnable() {
         public void run() {
             while (mProgressStatus < 100) {
                 mProgressStatus = doWork();

                 // Update the progress bar
                 mHandler.post(new Runnable() {
                     public void run() {
                         mProgress.setProgress(mProgressStatus);
                     }
                 });
             }
         }
     }).start();

我想使用两个类,一个类包含主线程,另一个类包含后台线程,它们使用相同的处理程序。我该如何实现? 我知道这很常见,但我发现很难完全实现。

1 个答案:

答案 0 :(得分:2)

如果您不想使用静态概念,可以从参数传递任何内容。在下面的代码中,我实现了两个类。正如您所问,我在两个线程类中都使用了公共处理程序。我将处理程序h1作为Runnable对象的参数传递,并将start()方法传递给那里,以触发另一个线程类的run()方法。包含run()方法的线程是UI(主)线程。我们必须使用UI线程来更新UI。工作者(后台)线程无法进行UI更新。工作人员与UI之间的通信是通过处理程序完成的。所以,我在UI线程类中定义了处理程序h2。当从后台线程类调用UI线程类构造函数时,我从构造函数的h1获取h2值。我使用h2进行沟通。实际上,h2和h1属于系统中的相同内存空间。

我在下面的两个课程中做过线程沟通,供你参考。

头等舱

 public class MainActivity extends AppCompatActivity {
    Handler h1;
    Thread t;
    EditText editText;
    private Bundle bb = new Bundle();

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

        editText = (EditText) findViewById(R.id.editText);

        h1 = new Handler(Looper.getMainLooper()) {

            @Override
            public void handleMessage(Message msg) {
                bb = msg.getData();
                String str = bb.getString("udd");
                editText.setText(str);
                System.out.println(str);
            }
        };
        t = new Thread(new MyRunnable(h1)); //I pass Runnable object in thread so that the code inside the run() method
        //of Runnable object gets executed when I start my thread here. But the code executes in new thread
        t.start(); //thread started

        try {
            t.sleep(1000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }


    }

}

第二课

public class MyRunnable implements Runnable {
    private Handler h2;
    public MyRunnable(Handler h) {
        this.h2 = h;
    }

    @Override
    public void run() {

        //everything inside rum method executes in new thread
        for(int i=0;i<10;i++) {
            Message m = Message.obtain(); //get null message
            Bundle b = new Bundle();
            b.putString("udd", "daju");
            m.setData(b);
            //use the handler to send message
            h2.sendMessage(m);

        }
    }
}

注意:当thread.start()发生时,它会触发Runnable类的运行,它会创建一个单独的线程。所以每次调用start()时,都会有一个新的线程,它具有相同的callee线程优先级。

希望,这对你有所帮助。