我们都知道Android应用程序只有一个主线程ActivityThread,这个主线程会创建一个Looper(Looper.prepare),而Looper又会关联一个MessageQueue,主线程Looper会在应用的生命周期内不断轮询(Looper.loop),从MessageQueue取出Message 更新UI。
链接:https://www.jianshu.com/p/e58992439793
主要是3个:ActivityThread,Handle,Looper
流程:
1、handle.postMessage 发送消息给主线程
2、主线程会根据它的轮训器looper不断的轮训MessageQueue当中的消息,通过调用消息队列的next方法,来获取我们需要的消息。
3、然后我们会计算出在调用dispatcherMessage这个方法前后的时间值,通过计算T2-T1的时间差,来判定是否超过了我们设定的阈值,如果超过了我们就会报出卡顿信息,
如果延迟发送了阈值的0.8倍的话,我们也会报出堆栈信息,cpu信息,内存信息
install方法:
stackSampler,CPUSampler,LooperMonitor
start方法:
Looper.getMainLooper().setMessageLogging(mBlockCanaryCore.monitor);
通过stackSampler和CPUSampler的doSampler最终打印时间的。
获得主线程的looper并打印时间
如果T1-T2>阈值时间,那么就回调onBlockEvent方法报出卡顿信息。