[发明专利]针对应用卡顿的处理方法、装置和电子设备有效
申请号: | 202010211585.7 | 申请日: | 2020-03-24 |
公开(公告)号: | CN111443957B | 公开(公告)日: | 2021-10-26 |
发明(设计)人: | 王小龙;赵俊;王凯 | 申请(专利权)人: | 华为技术有限公司 |
主分类号: | G06F9/445 | 分类号: | G06F9/445;G06F9/48;G06F9/50;G06F9/54 |
代理公司: | 北京汇思诚业知识产权代理有限公司 11444 | 代理人: | 冯伟 |
地址: | 518129 广东*** | 国省代码: | 广东;44 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 针对 应用 处理 方法 装置 电子设备 | ||
1.一种针对应用卡顿的处理方法,其特征在于,包括:
监控应用主线程的事件处理队列,判断所述事件处理队列中的新加入事件是否需要被优先响应;
当所述新加入事件需要被优先响应时,计算所述新加入事件在所述事件处理队列中的等待时间,判断所述等待时间是否超过预设时间阈值;
当所述等待时间超过所述预设时间阈值时,收回所述应用主线程的代码执行权;
在所述应用主线程的代码执行权被收回后,重新排列所述事件处理队列,包括:
前移所述新加入事件的排位,将所述新加入事件排在重排后的事件处理队列的第一位;
移除阻塞事件或后移阻塞事件的排位,其中,所述阻塞事件为所述事件处理队列被重排前,排在第一位且被主线程执行的事件;
在所述事件处理队列被重排完毕后,恢复所述应用主线程的代码执行权,令所述应用主线程执行所述重排后的事件处理队列。
2.根据权利要求1所述的方法,其特征在于,所述判断所述事件处理队列中的新加入事件是否需要被优先响应,包括:
判断所述新加入事件是否为用户输入事件;
当所述新加入事件为用户输入事件时,判定所述新加入事件需要被优先响应。
3.根据权利要求1所述的方法,其特征在于,所述监控应用主线程的事件处理队列,包括:
构建监控子线程;
使用所述监控子线程监控所述应用主线程的事件处理队列。
4.根据权利要求1所述的方法,其特征在于,所述判断所述事件处理队列中的新加入事件是否需要被优先响应之前,还包括:
判断所述新加入事件是否依赖其他事件;
当所述新加入事件不依赖其他事件时,判断所述事件处理队列中的新加入事件是否需要被优先响应。
5.根据权利要求1所述的方法,其特征在于,所述收回所述应用主线程的代码执行权,包括:
向所述应用主线程发中断消息,在所述应用主线程响应所述中断消息的过程中,收回所述应用主线程的代码执行权,将所述代码执行权交予系统框架重新分配。
6.根据权利要求1所述的方法,其特征在于,所述重新排列所述事件处理队列,还包括:
在所述重新排列所述事件处理队列的过程中,保持除所述阻塞事件以及所述新加入事件以外的其他事件相互间的排序不变。
7.根据权利要求1-6中任一项所述的方法,其特征在于,所述后移阻塞事件的排位,包括:
判断是否存在依赖所述阻塞事件的事件;
当存在依赖所述阻塞事件的事件时,在所述重排后的事件处理队列中,将所述阻塞事件排在依赖所述阻塞事件的事件之前。
8.根据权利要求7所述的方法,其特征在于,所述判断是否存在依赖所述阻塞事件的事件之后,还包括:
当不存在依赖所述阻塞事件的事件时,将所述阻塞事件排在所述重排后的事件处理队列的末尾。
9.根据权利要求1所述的方法,其特征在于,所述后移阻塞事件的排位,包括:将所述阻塞事件排在所述重排后的事件处理队列的第二位。
10.根据权利要求1所述的方法,其特征在于,所述移除阻塞事件,包括:
判断所述阻塞事件导致的重新排列所述事件处理队列的次数是否大于预设次数阈值;
当所述重新排列所述事件处理队列的次数大于预设次数阈值时,移除所述阻塞事件和/或输出提示信息。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于华为技术有限公司,未经华为技术有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202010211585.7/1.html,转载请声明来源钻瓜专利网。
- 上一篇:一种防止数据丢失的计算机系统及方法
- 下一篇:一种消息通信系统