源码位置:frameworks/base/services/core/java/com/android/server/Watchdog.java
Watchdog
在 SystemServer.java 启动,
HandlerChecker :
HandlerChecker 会把它的run方法提交给 它的变量 Handler中去执行,
如果run很快返回,那就说明这个Handler 运行正常,没有超时。
在其run方法中会去调用它的变量的 mMonitors数组中的每一个
Monitor的 monitor()方法,
Monitor 为接口,其实际的实际对象有如下类:
它的作用是检测这个类是否有死锁产生。
在调用run之前先取得当前时间,然后提交run给handler ,
后期再来调用这个 HandlerChecker 的 getCompletionStateLocked() 来查看完成状态,有4种类型: COMPLETED , WAITING,WAITED_HALF ,OVERDUE .
COMPLETED 表示 run方法是否已经执行完毕,
如果已经完成,则直接返回。
如果没有完成,则肯定超时了。
关于超时时间,有以下三个定义:
如果当前超时时间 latency 小于规定的超时时间的一半,则当前状态是
WAITING,
如果当前超时时间 latency 大于规定的超时时间的一半但小于规定的超时时间, 则当前状态是 WAITED_HALF 。
如果当前超时时间 latency 大于规定的超时时间, 则当前状态是 OVERDUE。
如果超时,则关闭系统:
Process.killProcess(Process.myPid());
System.exit(10);