Android|Android Crash 原理分析

android 中最重要的就是 Handler 机制了,简单来说 Handler 机制就是在一个死循环内部不断取走阻塞队列头部的 Message,这个阻塞队列在主线程中是唯一的,当没有 Message 时,循环就阻塞,当一旦有Message 时就立马被主线程取走并执行 Message
查看 android 源码可以发现在 ActivityThreadmain 方法( main 方法签名 public static void main(String[] args){}, 这个 main 方法是静态的,公有的,可以理解为应用的入口)最后执行了Looper.loop(),此方法内部是个死循环( for(; ; ) 循环),所以一般情况下主线程是不会退出的,除非抛出异常。
queue.next() 就是从阻塞队列里取走头部的 Message,当没有Message 时主线程就会阻塞在这里,一有Message 就会继续往下执行。androidview 绘制,事件分发,Activity 启动,Activity 的生命周期回调等等都是一个个的 Messageandroid 会把这些 Message 插入到主线程中唯一的 queue中,所有的消息都排队等待主线程的执行。
ActivityThreadmain 方法如下:

public static void main(String[] args) {... Looper.prepareMainLooper(); //创建主线程唯一的阻塞队列queue ... ActivityThread thread = new ActivityThread(); thread.attach(false); //执行初始化,往queue中添加Message等 ... Looper.loop(); //开启死循环,挨个执行Messagethrow new RuntimeException("Main thread loop unexpectedly exited"); }

Looper.loop() 关键代码如下:
for (; ; ) { Message msg = queue.next(); // might block ... msg.target.dispatchMessage(msg); //执行Message ... }

【Android|Android Crash 原理分析】android 消息机制伪代码如下:
public class ActivityThread {public static void main(String[]args){Queue queue=new Queue(); // 可以理解为一个加锁的,可以阻塞线程的ArrayListqueue.add(new Message(){ void run(){ ... print("android 启动了,下一步该往queue中插入启动主Activity的Message了"); Message msg=getMessage4LaunchMainActivity(); queue.add(msg); } }); for(; ; ){//开始死循环,for之后的代码永远也得不到执行 Messagemsg=queue.next(); msg.run(); } } }

    推荐阅读