Android WatchDog

https://blog.csdn.net/fu_kevin0606/article/details/64479489
https://blog.csdn.net/lezhang123/article/details/72537647
https://www.jianshu.com/p/af5c93fd84c6 java的线程锁
对于Monitor Checker而言,会调用实现类的monitor方法,譬如上文中提到的AMS.monitor()方法, 方法实现一般很简单,就是获取当前类的对象锁,如果当前对象锁已经被持有,则monitor()会一直处于wait状态,直到超时,这种情况下,很可能是线程发生了死锁。
monitor()因为获取不到锁,就一直处于等待状态,那么在HandlerChecker的run函数里面就没法给 mCompleted赋值为true, mCompleted的值一直处于false状态,因为线程阻塞在那了执行不到后面的: synchronized (Watchdog.this) {
mCompleted = true;
mCurrentMonitor = null;
}。
然后watchdog下次或者下下次检测时(每次间隔30秒),会结合mCompleted和上次发出的postAtFrontOfQueue的时间到现在的时间差,如果mCompleted还是false,而且时间差超过60秒就杀死systemServer。Looper Checker的检查也差不多这样的原理,Looper如果阻塞都不会跑到HandlerChecker的run函数,自然而然mCompleted是false的。后面的超时判断原理是一样的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值