Handler 原理分析

核心类,在主线程中定义:

Handler,ActivityThread,Looper,MessageQueue。

Looper类

  • 包含MessageQueue,Thread,ThreadLocal
  • 通过ThreadLocal.set(key) 保存线程唯一的Looper
  • 每个线程仅有一个Looper
    private static void prepare(boolean quitAllowed) {
        if (sThreadLocal.get() != null) {
            throw new RuntimeException("Only one Looper may be created per thread");
        }
        sThreadLocal.set(new Looper(quitAllowed));
    }

Looper.loop()

从 Looper类中的MessageQueue,不断取出message,调用msg.tartget.dispathMessage方法

1、取出message

复制代码
/**
     * Run the message queue in this thread. Be sure to call
     * {@link #quit()} to end the loop.
     */
    public static void loop() {
        final Looper me = myLooper();final MessageQueue queue = me.mQueue;for (;;) {
            Message msg = queue.next(); // might block
            if (msg == null) {
                // No message indicates that the message queue is quitting.
                return;
            }try {
                msg.target.dispatchMessage(msg);
            } catch (Exception exception) {
               
            } 
            msg.recycleUnchecked();
        }
    }
复制代码

2、dispatchMessage方法走向

复制代码
    /**
     * Handle system messages here.
     */
    public void dispatchMessage(@NonNull Message msg) {
        if (msg.callback != null) {
            handleCallback(msg);
        } else {
            if (mCallback != null) {
                if (mCallback.handleMessage(msg)) {
                    return;
                }
            }
            handleMessage(msg);
        }
    }
复制代码

Handler

  • 内部维护一个MessageQueue,指向Looper类中的MessageQueue
  • sendMessage()添加到MessageQueue中
复制代码
    public boolean sendMessageAtTime(@NonNull Message msg, long uptimeMillis) {
        MessageQueue queue = mQueue;
        if (queue == null) {
            RuntimeException e = new RuntimeException(
                    this + " sendMessageAtTime() called with no mQueue");
            Log.w("Looper", e.getMessage(), e);
            return false;
        }
        return enqueueMessage(queue, msg, uptimeMillis);
    }
复制代码
复制代码
    private boolean enqueueMessage(@NonNull MessageQueue queue, @NonNull Message msg,
            long uptimeMillis) {
        msg.target = this;
        msg.workSourceUid = ThreadLocalWorkSource.getUid();

        if (mAsynchronous) {
            msg.setAsynchronous(true);
        }
        return queue.enqueueMessage(msg, uptimeMillis);
    }
复制代码

参考:Android Handler 机制实现原理分析_Android_脚本之家 (jb51.net)

详细理解: 都 2021 年了,还有人在研究 Handler? - 掘金 (juejin.cn)

posted @   随易来了  阅读(21)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
点击右上角即可分享
微信分享提示