zoukankan      html  css  js  c++  java
  • 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!真是太棒了!

  • 相关阅读:
    IP报头结构
    C#组件项目设置与开发应用范例
    UDP数据报协议
    WOW 各等级属性换算表
    清理SQLSERVER日志
    正则表达式匹配EXCEL地址字符串
    TCP数据段格式
    MAC地址结构
    (转载) Delphi中打印条码的方法
    为了使用uart2, 发现6252中define了 SCCB_SERIAL_CLK_PIN 值为 22, 为了避免冲突, 手动修改其值为 23
  • 原文地址:https://www.cnblogs.com/chenjianxiang/p/3913644.html
Copyright © 2011-2022 走看看