码迷,mamicode.com
首页 > 移动开发 > 详细

安卓线程相关 HandlerThread Handler Thread Looper Message Runnable

时间:2014-09-04 22:20:50      阅读:254      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   color   os   使用   ar   strong   art   

本文由PurpleSword(jzj1993)原创,转载请注明
原文网址 http://blog.csdn.net/jzj1993

安卓主线程(UI线程)是线程不安全的:对UI控件的
操作都应在主线程中完成;UI线程不应执行耗时操作,以免程序不响应(即ANR异常)


实现新线程的常用方法(注意要调用start方法启动新线程而不是run方法):

一、定义类,实现Runnable接口

    class MyRunnable implements Runnable {
        /**
         * 实现接口的run方法
         */
        @Override
        public void run() {
            // run方法的中程序体将在新线程中执行
        }
    }
    new Thread(new MyRunnable()).start();


二、简洁写法

        new Thread(new Runnable() {
            @Override
            public void run() {
                // 新线程操作
            }
        }).start();


三、定义类,继承Thread(不推荐):

    class MyThread extends Thread {
        /**
         * 覆写run方法
         */
        @Override
        public void run() {
            // 新线程操作
        }
    }
    new MyThread().start();


Thread和Runnable关系

    public class Thread extends Object implements Runnable {
    }


创建UI线程/主线程的Handler

一、(推荐写法,用于不处理消息,只是接收Runnable的情况下)

    // 无参数实例化时,会创建当前正在运行线程(即主线程)的Handler
    Handler handler = new Handler();

如果handler需要处理消息,按照以下写法将会产生警告This Handler class should be static or leaks might occur。此时可使用方法二)

    Handler handler = new Handler() {
        @Override
        public void handleMessage(Message msg) {
            switch (msg.what) {
            }
        }
    };

二、(缺点在于需要定义一个新的类,写起来比较麻烦)

    // 无参数实例化时,会创建当前正在运行线程(即主线程)的Handler
    private Handler handler = new MyHandler() {
        // 处理其他线程发送的消息
        @Override
        public void handleMessage(Message msg) {
            Log.d("msg""msg what = " + msg.what);
            switch (msg.what) {
            }
        }
    };

    protected static class MyHandler extends Handler {
    }

三、(推荐写法,可用于接收Runnable和处理消息的情况下)

    boolean handleMessage(Message msg) {
        switch (msg.what) {
        }
        return true;
    }

    private final Handler mainHandler = new Handler(Looper.getMainLooper(),
            new Handler.Callback() {
                @Override
                public boolean handleMessage(Message msg) {
                    return ActivityMain.this.handleMessage(msg);
                }
            });

在UI线程中执行程序

        handler.post(new Runnable(){
            @Override
            public void run() {
                // 操作UI控件等...
            }
        });


创建新线程的Handler

    private HandlerThread handlerThread;
    private Handler handler;

    this.handlerThread = new HandlerThread(getClass().getSimpleName());
    this.handlerThread.start();
    this.handler = new Handler(this.handlerThread.getLooper(),
            new Handler.Callback() {
                public boolean handleMessage(Message msg) {
                    return NewThread.this.handleMessage(msg);
                }
            });

    /**
     * 处理消息
     * 
     * @param msg
     * @return
     */
    private boolean handleMessage(Message msg) {
        switch (msg.what) {
        }
        return true;
    }

通过Message进行线程间通信:在任意线程中向其他线程Handler发送消息

    /**
     * 向线程Handler发送消息
     * 
     * @param id
     * @param o
     */
    protected void sendMsg(int id, Object o) {
        if (handler != null) {
            Message msg = Message.obtain();
            msg.obj = o;
            msg.what = id;
            handler.sendMessage(msg);
        }
    }

    /**
     * 向线程Handler发送消息
     * 
     * @param what
     */
    protected void sendMsg(int what) {
        if (handler != null) {
            handler.sendEmptyMessage(what);
        }
    }


    handler.sendMessageDelayed(msgmilliseconds);

    Message.obtain(handlerwhatobj).sendToTarget();


安卓线程相关 HandlerThread Handler Thread Looper Message Runnable

标签:style   blog   http   color   os   使用   ar   strong   art   

原文地址:http://blog.csdn.net/jzj1993/article/details/39060053

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!