Android 经典 Crash 分析,Android Crash 原理分析

本文深入解析了Android中的Handler机制,它在主线程中通过Looper循环处理Message队列,负责UI更新、事件分发等任务。当Message队列为空时,主线程会阻塞,有新Message则立即执行。ActivityThread的main方法启动了这个机制,并通过Looper.prepareMainLooper()和Looper.loop()创建和运行消息循环。
摘要由CSDN通过智能技术生成

android 中最重要的就是 Handler 机制了,简单来说 Handler 机制就是在一个死循环内部不断取走阻塞队列头部的 Message,这个阻塞队列在主线程中是唯一的,当没有 Message 时,循环就阻塞,当一旦有Message 时就立马被主线程取走并执行 Message。

查看 android 源码可以发现在 ActivityThread 中 main 方法( main 方法签名 public static void main(String[] args){}, 这个 main 方法是静态的,公有的,可以理解为应用的入口)最后执行了Looper.loop(),此方法内部是个死循环( for(;;) 循环),所以一般情况下主线程是不会退出的,除非抛出异常。

queue.next() 就是从阻塞队列里取走头部的 Message,当没有Message 时主线程就会阻塞在这里,一有Message 就会继续往下执行。android 的 view 绘制,事件分发,Activity 启动,Activity 的生命周期回调等等都是一个个的 Message,android 会把这些 Message 插入到主线程中唯一的 queue中,所有的消息都排队等待主线程的执行。

ActivityThread 的 main 方法如下:

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();

}

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值