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();//开启死循环,挨个执行Message

        throw new RuntimeException("Main thread loop unexpectedly exited");
}

Looper.loop() 关键代码如下:

 for (;;) {
            Message msg = queue.next(); // might block
            ...
            msg.target.dispatchMessage(msg);//执行Message
            ...
   }

android 消息机制伪代码如下:

public class ActivityThread {

    public static void main(String[]args){
        
        Queue queue=new Queue();// 可以理解为一个加锁的,可以阻塞线程的ArrayList
        
        queue.add(new Message(){
            void run(){
                ...
                print("android 启动了,下一步该往queue中插入启动主Activity的Message了");
                Message msg=getMessage4LaunchMainActivity();
                queue.add(msg);
            }   
        });
        
        for(;;){//开始死循环,for之后的代码永远也得不到执行
            Message  msg=queue.next();
            
            msg.run();  
        }
    }
}

你可能感兴趣的:(Android Crash 原理分析)