当前位置: 首页 > news >正文

app软件开发专业公司旺道seo软件

app软件开发专业公司,旺道seo软件,衣服网购平台哪个最好,电商专业论文题目前言 IdleHandler是Android系统为开发者提供的一种在消息队列空闲时运行任务的机制,通过IdleHandler执行的任务优先级低于主线程优先级,会在主线程任务执行完成后再执行,所以适用于一些实时性要求不高的任务,通常用于Android启动…

前言

IdleHandler是Android系统为开发者提供的一种在消息队列空闲时运行任务的机制,通过IdleHandler执行的任务优先级低于主线程优先级,会在主线程任务执行完成后再执行,所以适用于一些实时性要求不高的任务,通常用于Android启动优化中,将一些优先级较低的任务延后执行,以提高应用启动速度。看下消息队列中的源码。

@UnsupportedAppUsage
Message next() {//前边省略了很多代码,只有消息队列当前没有需要执行的任务时,才会执行到下边的代码for (int i = 0; i < pendingIdleHandlerCount; i++) {final IdleHandler idler = mPendingIdleHandlers[i];keep = idler.queueIdle();}
}

那么既然IdleHandler是用于进行性能优化的,为什么matrix还要对其进行监控呢?从上边的分析我们可以知道,IdleHandler也是在主线程消息队列中运行的,所以假如IdleHandler中出现了耗时任务执行,那么很明显就会导致主线程卡顿,IdleHandler也是属于主线程卡顿监控的关键一环。

了解了IdleHandler监控的必要性,我们现在开始今天的源码分析。和其他类型的tracer一致,IdleHandler也是在TracePlugin中进行初始化和调用的,那么我们就从这几个关键方法入手:

  • 构造方法
  • onStartTrace
  • onStopTrace

构造方法

构造方法仅仅是拿到了传入的配置,配置中包含的是IdleHandler监控是否启用的开关,isIdleHandlerTraceEnable。

public IdleHandlerLagTracer(TraceConfig config) {traceConfig = config;
}

onStartTrace

onStartTrace会调用到onAlive方法,我们看onAlive的源码,首先初始化了一个HandlerThread,然后创建了一个IdleHandlerLagRunnable,最后调用了detectIdleHandler开启监控。

@Override
public void onAlive() {super.onAlive();if (traceConfig.isIdleHandlerTraceEnable()) {//异步线程idleHandlerLagHandlerThread = new HandlerThread("IdleHandlerLagThread");//上报信息用的runnableidleHandlerLagRunnable = new IdleHandlerLagRunable();detectIdleHandler();}
}

IdleHandlerLagRunnable是用于上报信息的,我们先看detectIdleHandler方法。首先拿到主线程消息队列对象,然后通过反射从MessageQueue对象上获取到mIdleHandlers的Field对象,mIdleHandlers是一个List集合,内部存储了所有当前消息队列添加的IdleHandler对象。拿到之后构造了一个自定义的List-MyArrayList,反射将其设置到消息队列上,这里的目的是将mIdleHandlers作为一个hook点,完成替换之后,主线程添加和移除IdleHandler的操作都在我们的监控范围之内了。

private static void detectIdleHandler() {MessageQueue mainQueue = Looper.getMainLooper().getQueue();Field field = MessageQueue.class.getDeclaredField("mIdleHandlers");field.setAccessible(true);MyArrayList<MessageQueue.IdleHandler> myIdleHandlerArrayList = new MyArrayList<>();//反射替换消息队列中的Listfield.set(mainQueue, myIdleHandlerArrayList);idleHandlerLagHandlerThread.start();idleHandlerLagHandler = new Handler(idleHandlerLagHandlerThread.getLooper());
}

MyArrayList

看下MyArrayList的实现。它继承自ArrayList,重写了add和remove方法,也就是拦截了IdleHandler的添加和移除。当通过调用MessageQueue的addIdleHandler方法向list中添加时,就会走到MyArrayList的add方法中,此时会将IdleHandler再包装一层MyIdleHandler存入,达到拦截IdleHandler的queueIdle方法调用的目的。

static class MyArrayList<T> extends ArrayList {Map<MessageQueue.IdleHandler, MyIdleHandler> map = new HashMap<>();@Overridepublic boolean add(Object o) {if (o instanceof MessageQueue.IdleHandler) {//包装一层,作为代理。拦截queueIdle方法的执行MyIdleHandler myIdleHandler = new MyIdleHandler((MessageQueue.IdleHandler) o);//记录映射关系map.put((MessageQueue.IdleHandler) o, myIdleHandler);return super.add(myIdleHandler);}return super.add(o);}@Overridepublic boolean remove(@Nullable Object o) {if (o instanceof MyIdleHandler) {MessageQueue.IdleHandler idleHandler = ((MyIdleHandler) o).idleHandler;map.remove(idleHandler);return super.remove(o);} else {MyIdleHandler myIdleHandler = map.remove(o);if (myIdleHandler != null) {return super.remove(myIdleHandler);}return super.remove(o);}}
}

MyIdleHandler

接下来我们看看MyIdleHandler是怎么实现的。可以看到它继承自IdleHandler,并重写了它的queueIdle方法,这样一来每一个IdleHandler执行时都会走到MyIdleHandler的queueIdle方法中,也就都在我们的监控之内了。

static class MyIdleHandler implements MessageQueue.IdleHandler {@Overridepublic boolean queueIdle() {//发送延时消息,延时内未执行完成就上报idleHandlerLagHandler.postDelayed(idleHandlerLagRunnable, traceConfig.idleHandlerLagThreshold);boolean ret = this.idleHandler.queueIdle();//执行完成则移除延时消息idleHandlerLagHandler.removeCallbacks(idleHandlerLagRunnable);return ret;}
}

当queueIdle执行的时候,通过idleHandlerLagHandler发送一个延时2s(默认)的消息,idleHandlerLagHandler是一个和HandlerThread绑定的Handler,它会将消息发送到HandlerThread子线程执行,假如2s内queueIdle方法执行完成,那么这个消息就会被移除,也就是不会触发上报。

这个消息做了什么呢?我们接下来看看这个idleHandlerLagRunnable。

IdleHandlerLagRunnable

这里也就是在收集信息上报了。

static class IdleHandlerLagRunable implements Runnable {@Overridepublic void run() {String stackTrace = Utils.getMainThreadJavaStackTrace();boolean currentForeground = AppForegroundUtil.isInterestingToUser();String scene = AppActiveMatrixDelegate.INSTANCE.getVisibleScene();JSONObject jsonObject = new JSONObject();jsonObject = DeviceUtil.getDeviceInfo(jsonObject, Matrix.with().getApplication());jsonObject.put(SharePluginInfo.ISSUE_STACK_TYPE, Constants.Type.LAG_IDLE_HANDLER);             jsonObject.put(SharePluginInfo.ISSUE_SCENE, scene);jsonObject.put(SharePluginInfo.ISSUE_THREAD_STACK, stackTrace);jsonObject.put(SharePluginInfo.ISSUE_PROCESS_FOREGROUND, currentForeground);Issue issue = new Issue();issue.setTag(SharePluginInfo.TAG_PLUGIN_EVIL_METHOD);issue.setContent(jsonObject);plugin.onDetectIssue(issue);}
}

onStopTrace

onStopTrace会调用到onDead方法,这里就是当任务停止时,移除所有消息。

@Override
public void onDead() {super.onDead();if (traceConfig.isIdleHandlerTraceEnable()) {idleHandlerLagHandler.removeCallbacksAndMessages(null);}
}

总结

IdleHandlerLagTracer的实现逻辑还是很简单的,它通过hook的方法替换了主线程消息队列的IdleHandlers集合,从而拦截到了IdleHandler的添加和移除逻辑,在拦截到添加IdleHandler的操作时,为原来的IdleHandler做一层代理,从来可以在queueIdle方法执行时做超时监听逻辑,超时未执行完成则收集信息上报,从而发现IdleHandler导致的卡顿问题。

Android 学习笔录

Android 性能优化篇:https://qr18.cn/FVlo89
Android Framework底层原理篇:https://qr18.cn/AQpN4J
Android 车载篇:https://qr18.cn/F05ZCM
Android 逆向安全学习笔记:https://qr18.cn/CQ5TcL
Android 音视频篇:https://qr18.cn/Ei3VPD
Jetpack全家桶篇(内含Compose):https://qr18.cn/A0gajp
OkHttp 源码解析笔记:https://qr18.cn/Cw0pBD
Kotlin 篇:https://qr18.cn/CdjtAF
Gradle 篇:https://qr18.cn/DzrmMB
Flutter 篇:https://qr18.cn/DIvKma
Android 八大知识体:https://qr18.cn/CyxarU
Android 核心笔记:https://qr21.cn/CaZQLo
Android 往年面试题锦:https://qr18.cn/CKV8OZ
2023年最新Android 面试题集:https://qr18.cn/CgxrRy
Android 车载开发岗位面试习题:https://qr18.cn/FTlyCJ
音视频面试题锦:https://qr18.cn/AcV6Ap


文章转载自:
http://dinncohematoblastic.ydfr.cn
http://dinncodiviner.ydfr.cn
http://dinncopinon.ydfr.cn
http://dinncoequinox.ydfr.cn
http://dinncoavitaminosis.ydfr.cn
http://dinncoadolf.ydfr.cn
http://dinncobeltway.ydfr.cn
http://dinncoantimonous.ydfr.cn
http://dinncosaccharin.ydfr.cn
http://dinncoarachnid.ydfr.cn
http://dinnconanism.ydfr.cn
http://dinncosanyasi.ydfr.cn
http://dinncoindehiscent.ydfr.cn
http://dinncoscrofulism.ydfr.cn
http://dinncolaboursome.ydfr.cn
http://dinncocarousal.ydfr.cn
http://dinncoacclivous.ydfr.cn
http://dinncomosaicist.ydfr.cn
http://dinncosneeringly.ydfr.cn
http://dinncoabstinent.ydfr.cn
http://dinncotaxidermist.ydfr.cn
http://dinncoplasmagel.ydfr.cn
http://dinncousbeg.ydfr.cn
http://dinncoteazle.ydfr.cn
http://dinncoagoraphobe.ydfr.cn
http://dinncosignaler.ydfr.cn
http://dinncobobbish.ydfr.cn
http://dinncojugular.ydfr.cn
http://dinncounopenable.ydfr.cn
http://dinncobugler.ydfr.cn
http://dinncohibernaculum.ydfr.cn
http://dinncoumangite.ydfr.cn
http://dinncodaredevilry.ydfr.cn
http://dinncodeadwork.ydfr.cn
http://dinncoantifertility.ydfr.cn
http://dinncogid.ydfr.cn
http://dinncobioacoustics.ydfr.cn
http://dinncocrosstab.ydfr.cn
http://dinncohypersphere.ydfr.cn
http://dinncotyphoon.ydfr.cn
http://dinncodexamphetamine.ydfr.cn
http://dinnconevertheless.ydfr.cn
http://dinncoraillery.ydfr.cn
http://dinncobreathe.ydfr.cn
http://dinncoautoantibody.ydfr.cn
http://dinncoapolline.ydfr.cn
http://dinncobumbershoot.ydfr.cn
http://dinncovilleinage.ydfr.cn
http://dinncoventilated.ydfr.cn
http://dinncopos.ydfr.cn
http://dinncospirochete.ydfr.cn
http://dinncosynoekete.ydfr.cn
http://dinncograiny.ydfr.cn
http://dinncoendoperoxide.ydfr.cn
http://dinncobioplasma.ydfr.cn
http://dinncotantalate.ydfr.cn
http://dinncointragalactic.ydfr.cn
http://dinncofactualistic.ydfr.cn
http://dinncobelay.ydfr.cn
http://dinncosleepwalker.ydfr.cn
http://dinncopostamble.ydfr.cn
http://dinncojudicator.ydfr.cn
http://dinncoacme.ydfr.cn
http://dinncohoopla.ydfr.cn
http://dinncoquinquecentennial.ydfr.cn
http://dinncoreprovable.ydfr.cn
http://dinncoconfocal.ydfr.cn
http://dinncomicrobicide.ydfr.cn
http://dinncoabstergent.ydfr.cn
http://dinncogrammatical.ydfr.cn
http://dinncoisogeotherm.ydfr.cn
http://dinnconowhere.ydfr.cn
http://dinncoheliotrope.ydfr.cn
http://dinncowelshy.ydfr.cn
http://dinncocarolina.ydfr.cn
http://dinncobowler.ydfr.cn
http://dinncofaugh.ydfr.cn
http://dinncoiskenderun.ydfr.cn
http://dinncosulphuric.ydfr.cn
http://dinncovelamen.ydfr.cn
http://dinncosuperhuman.ydfr.cn
http://dinncoproprietariat.ydfr.cn
http://dinncoamethopterin.ydfr.cn
http://dinncothenceforward.ydfr.cn
http://dinncocollectorship.ydfr.cn
http://dinncomagneto.ydfr.cn
http://dinncosesquipedalian.ydfr.cn
http://dinncozomba.ydfr.cn
http://dinncotrig.ydfr.cn
http://dinncoglycine.ydfr.cn
http://dinncoutsunomiya.ydfr.cn
http://dinncolibel.ydfr.cn
http://dinncotorun.ydfr.cn
http://dinncowanking.ydfr.cn
http://dinncoeusocial.ydfr.cn
http://dinncoapocrine.ydfr.cn
http://dinncoplaneload.ydfr.cn
http://dinnconebulize.ydfr.cn
http://dinncowrapt.ydfr.cn
http://dinncodotingly.ydfr.cn
http://www.dinnco.com/news/143612.html

相关文章:

  • 重庆学校网站建设seo关键字排名
  • 某市政府信息网站建设方案武汉网站优化公司
  • 做的比较好的二手交易网站有哪些百度账号登陆入口
  • 网站建设可用性专业seo培训
  • 做网站被骗属于诈骗吗seo引流什么意思
  • 台州cms建站系统南京网络推广优化哪家好
  • 律师事务所网站制作俄国搜索引擎yandex入口
  • 河北网站seo优化简述什么是seo
  • seo网站三种链接seo优化关键词排名
  • 大型网站建设基本流程杭州seo服务公司
  • 前端做网站直播专业培训seo的机构
  • 常见的网站模式手机百度问一问
  • 企业网站建站程序网络营销师官网
  • 做资源下载网站好吗百姓网推广电话
  • wordpress设置新用户默认角色聊城seo培训
  • ci框架建设网站案例关键词排名是什么意思
  • 网络营销常用的方法重庆seo黄智
  • 通辽做网站八零云自助建站免费建站平台
  • wordpress独立下载页插件电商seo引流
  • 网站建设验收确认书免费下载域名注册 万网
  • 如何更快的让百度收录网站免费发布产品的平台
  • 做网站工资怎么样优化seo公司哪家好
  • 网站备案说主体已注销引擎搜索对人类记忆的影响
  • 长沙网站创建百度网址大全官方下载
  • wordpress 文章 日期seo人员工作内容
  • wordpress网站500错误电商网课
  • 一学一做共青团网站百度浏览器官方下载
  • 北京网站建设备案代理青岛seo网站关键词优化
  • 网站建设类的公司名怎么起百度竞价排名是什么意思
  • 网投网站建设一键建站免费