Android 再谈handler

今天在做http网络事件的响应网络接收处理一般不能放在主线程中使用,目前也只会使用AsyncTask进行处理!之前虽然写过handler处理的一些文章但是发现全不会了!无奈~

关于handler某位兄弟已经整理的很透彻了!现在引用下原话如下:

Handler监听者框架:子线程是事件源,主线程是监听者。
Handler作为子线程的监听器出现:主线程中生成Handler的子类,并重写handleMessage(Message msg) 方法,用来对子线程响应。子线程调用Hanlder的sendMessage(message)发送事件。

import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.app.Activity;
import android.util.Log;
import android.widget.TextView;

public class MainActivity extends Activity {

    private final static String TAG = "ThreadTest";
    TextView myTv = null;
    int i = 0;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        myTv = (TextView) this.findViewById(R.id.tv1);
        // 执行该线程
        new Thread(runnable).start();
    }
    /**
     * 主线程监听者
     */
    Handler myHandler = new Handler() {
        public void handleMessage(android.os.Message msg) {
            Log.i(TAG, "begin--->handleMessage");
            if (msg.what == 0x000001) {
                myTv.setText(String.valueOf(i));
            }
            Log.i(TAG, "end--->handleMessage");
            super.handleMessage(msg);
        };
    };
    
    /**
     * 子线程事件源
     */
    Runnable runnable = new Runnable() {
        @Override
        public void run() {
            while (!Thread.currentThread().isInterrupted()) {
                i++;
                Message msg = new Message();
                msg.what = 0x000001;
                Log.i(TAG, "begin--->sendMessage");
                myHandler.sendMessage(msg);
                Log.i(TAG, "end--->sendMessage");
                Log.i(TAG, "begin--->dosomething");
                try {
                    Thread.sleep(1000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                Log.i(TAG, "end--->dosomething");
            }
        }
    };

}

打印下输出:发现它并不是等dosomething执行完毕之后再调用handlemessage事件,而是一旦调用sendmessage后就会执行handlemessage。

Handler钩子方式:在主线程中生成一个Hanlder,用Handler的Post(Runnable)方法可以将Runnable钩到主线程中运行。

import android.os.Bundle;
import android.os.Handler;
import android.app.Activity;
import android.widget.TextView;

public class MainActivity extends Activity {

    private final static String TAG = "ThreadTest";
    TextView myTv = null;
    //handler在主线程中创建,调用post的时候钩子会把它钩回主线程
    Handler  myHandler = new Handler();
    int i = 0;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        myTv = (TextView) this.findViewById(R.id.tv1);
        new Thread(runnable1).start();
    }
    
    /**
     * 子线程
     */
    Runnable runnable1 = new Runnable() {
        @Override
        public void run() {
            while (true) {
                i++;
                myHandler.post(runnable2);
                try {
                    Thread.sleep(1000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        }
    };
    
    /**
     * 使用钩子将该子线程钩到主线程中
     */
    Runnable runnable2 = new Runnable() {
        @Override
        public void run() {
            myTv.setText(String.valueOf(i));
        }
    };

}

对于我们有了这样子的一个handler,如果需要进行一个非常耗时的网络请求,也不必担心迟迟无法显示activity。因为下载的任务交给了我们的子线程。当完成任务的时候我们可以调用sendMessage方法,通知主线程更新UI。bingo!真是太棒了!

原文地址:https://www.cnblogs.com/chenjianxiang/p/3913644.html