CN110188016B - 应用程序无响应阻塞的检测方法、终端以及存储介质 - Google Patents
应用程序无响应阻塞的检测方法、终端以及存储介质 Download PDFInfo
- Publication number
- CN110188016B CN110188016B CN201910441271.3A CN201910441271A CN110188016B CN 110188016 B CN110188016 B CN 110188016B CN 201910441271 A CN201910441271 A CN 201910441271A CN 110188016 B CN110188016 B CN 110188016B
- Authority
- CN
- China
- Prior art keywords
- main thread
- task
- executed
- thread
- same
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/3003—Monitoring arrangements specially adapted to the computing system or computing system component being monitored
- G06F11/302—Monitoring arrangements specially adapted to the computing system or computing system component being monitored where the computing system component is a software system
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/3051—Monitoring arrangements for monitoring the configuration of the computing system or of the computing system component, e.g. monitoring the presence of processing resources, peripherals, I/O links, software programs
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Computing Systems (AREA)
- Physics & Mathematics (AREA)
- Quality & Reliability (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Mathematical Physics (AREA)
- Debugging And Monitoring (AREA)
Abstract
本申请实施例公开一种应用程序无响应阻塞的检测方法、终端以及计算机可读存储介质,该应用程序无响应阻塞的检测方法包括:在应用程序启动时启动监控线程,并通过监控线程每隔第一预设时间触发一次监控任务;在监控任务被触发的情况下,判断应用程序的主线程当前执行的任务与前一次监控任务被触发时主线程执行的任务是否相同;在任务相同的情况下,判断第二预设时间前后的主线程的堆栈信息是否相同;在第二预设时间前后的主线程的堆栈信息相同的情况下,确定主线程发生阻塞。本申请实施例通过在应用程序启动时启动监控线程,在任务相同、堆栈信息相同时确定主线程发生阻塞;使用简单,可精确定位到主线程阻塞位置,不耗费CPU和内存资源。
Description
技术领域
本申请实施例涉及终端技术领域,尤其涉及一种应用程序无响应阻塞的检测方法、终端以及计算机可读存储介质。
背景技术
对于运行于安卓***中的应用程序,若该应用程序在一段时间内响应不够灵敏,则***会向用户显示一个对话框,用户可以选择“等待”来让应用程序继续运行,也可以选择“强制关闭”,这个对话框称作ANR(Application Not Responding,应用程序无响应)对话框。
当某一终端上的应用程序出现ANR之后,开发人员通常都需要去定位ANR出现的原因,进而来对该应用程序进行修复处理。通常来说,通过以下两种信息分析ANR发生的原因:一种是***服务与应用程序通信,当达到一定时间后应用程序端未处理完事务并回应***服务端,服务端报出应用程序端ANR;另一种是主线程在执行完一个任务后如果发现这个任务执行的时间过长,则把这个任务的信息打印出来。
现有技术存在的问题是,若***检测发现客户端已经阻塞超时,再打印堆栈信息,此时客户端主线程阻塞的函数与方法已经执行完成了,打印出来的堆栈信息没有参考意义;若客户端的Looper执行完一个任务后发现执行时间太长,然后打印出这个任务信息,但是任务执行的类容非常多,很难发现是执行到某个具体的方法引起阻塞。
发明内容
有鉴于此,本申请实施例的目的在于提供一种应用程序无响应阻塞的检测方法、终端以及计算机可读存储介质,以解决现有技术中ANR的排查方法存在操作复杂度较高、难以分析ANR发生原因的问题。
本申请实施例解决上述技术问题所采用的技术方案如下:
根据本申请实施例的一个方面,提供的一种应用程序无响应阻塞的检测方法,该方法用于终端,所述应用程序无响应阻塞的检测方法包括:
在应用程序启动时启动监控线程,并通过所述监控线程每隔第一预设时间触发一次监控任务;
在所述监控任务被触发的情况下,判断所述应用程序的主线程当前执行的任务与前一次监控任务被触发时所述主线程执行的任务是否相同;
在所述主线程当前执行的任务与前一次监控任务被触发时所述主线程执行的任务相同的情况下,判断第二预设时间前后的所述主线程的堆栈信息是否相同;
在所述第二预设时间前后的所述主线程的堆栈信息相同的情况下,确定所述主线程发生阻塞。
在一种可能的实施方式中,所述在所述监控任务被触发的情况下,判断所述应用程序的主线程当前执行的任务与前一次监控任务被触发时所述主线程执行的任务是否相同包括:
在所述监控任务被触发的情况下,通过所述监控线程获取所述主线程当前执行的任务的哈希代码值、前一次监控任务被触发时所述主线程执行的任务的哈希代码值;
将所述主线程当前执行的任务的哈希代码值与前一次监控任务被触发时所述主线程执行的任务的哈希代码值进行比较;
在所述主线程当前执行的任务的哈希代码值与前一次监控任务被触发时所述主线程执行的任务的哈希代码值相同的情况下,确定所述应用程序的主线程当前执行的任务与前一次监控任务被触发时所述主线程执行的任务相同。
在一种可能的实施方式中,所述在所述主线程当前执行的任务与前一次监控任务被触发时所述主线程执行的任务相同的情况下,判断第二预设时间前后的所述主线程的堆栈信息是否相同包括:
在所述主线程当前执行的任务与前一次监控任务被触发时所述主线程执行的任务相同的情况下,保存所述主线程的堆栈信息;
在所述第二预设时间之后,重新获取所述主线程的堆栈信息;
将保存的所述主线程的堆栈信息和重新获取的所述主线程的堆栈信息进行对比,根据对比结果确定所述第二预设时间前后所述主线程的堆栈信息是否相同。
在一种可能的实施方式中,所述在所述第二预设时间前后的所述主线程的堆栈信息相同的情况下,确定所述主线程发生阻塞,之后还包括:
在确定所述主线程发生阻塞的情况下,打印日志信息;所述日志信息包括所述主线程的堆栈信息、以及所述主线程当前执行的任务的***时间。
在一种可能的实施方式中,所述打印日志信息,之前还包括:
在确定所述主线程发生阻塞的情况下,获取所述主线程当前执行的任务的派遣时间;
将所述主线程当前执行的任务的派遣时间折算为所述主线程当前执行的任务的***时间。
在一种可能的实施方式中,所述在所述第二预设时间前后的所述主线程的堆栈信息相同的情况下,确定所述主线程发生阻塞,之后还包括:
判断所述主线程发生阻塞的时长是否超过预设时长阈值;
在所述主线程发生阻塞的时长超过预设时长阈值的情况下,获取备份的恢复数据;
根据所述备份的恢复数据重新启动所述应用程序。
在一种可能的实施方式中,所述根据所述备份的恢复数据重新启动所述应用程序,之后还包括:
在根据所述备份的恢复数据重新启动所述应用程序失败的情况下,删除所述应用程序的数据,重新启动所述应用程序。
在一种可能的实施方式中,所述监控线程为独立的、低优先级的守护进程且拥有自己的消息循环Looper。
根据本申请实施例的另一个方面,提供的一种终端,所述终端包括存储器、处理器及存储在所述存储器上并可在所述处理器上运行的应用程序无响应阻塞的检测程序,所述应用程序无响应阻塞的检测程序被所述处理器执行时实现上述的应用程序无响应阻塞的检测方法的步骤。
根据本申请实施例的另一个方面,提供的一种计算机可读存储介质,所述计算机可读存储介质上存储有应用程序无响应阻塞的检测程序,所述应用程序无响应阻塞的检测程序被处理器执行时实现上述的应用程序无响应阻塞的检测方法的步骤。
本申请实施例的应用程序无响应阻塞的检测方法、终端以及计算机可读存储介质,通过在应用程序启动时启动监控线程,在任务相同、堆栈信息相同时确定主线程发生阻塞;解决了现有技术中ANR的排查方法存在操作复杂度较高、难以分析ANR发生原因的问题;使用简单,可精确定位到主线程阻塞位置,不耗费CPU和内存资源。
附图说明
图1为实现本申请各个实施例的移动终端的硬件结构示意图;
图2为本申请实施例提供的一种通信网络***架构图;
图3为本申请第一实施例的应用程序无响应阻塞的检测方法流程示意图;
图4为本申请实施例的应用程序无响应阻塞的检测过程流程示意图;
图5为本申请第二实施例的终端结构示意图。
本申请目的的实现、功能特点及优点将结合实施例,参照附图做进一步说明。
具体实施方式
为了使本申请所要解决的技术问题、技术方案及有益效果更加清楚、明白,以下结合附图和实施例,对本申请进行进一步详细说明。应当理解,此处所描述的具体实施例仅仅用以解释本申请,并不用于限定本申请。
在后续的描述中,使用用于表示元件的诸如“模块”、“部件”或“单元”的后缀仅为了有利于本发明的说明,其本身没有特定的意义。因此,“模块”、“部件”或“单元”可以混合地使用。
终端可以以各种形式来实施。例如,本发明中描述的终端可以包括诸如手机、平板电脑、笔记本电脑、掌上电脑、PDA(Personal Digital Assistant,个人数字助理)、PMP(Portable Media Player,便捷式媒体播放器)、导航装置、可穿戴设备、智能手环、计步器等移动终端,以及诸如数字TV、台式计算机等固定终端。
后续描述中将以移动终端为例进行说明,本领域技术人员将理解的是,除了特别用于移动目的的元件之外,根据本发明的实施方式的构造也能够应用于固定类型的终端。
请参阅图1,其为实现本发明各个实施例的一种移动终端的硬件结构示意图,该移动终端100可以包括:RF(Radio Frequency,射频)单元101、WiFi模块102、音频输出单元103、A/V(音频/视频)输入单元104、传感器105、显示单元106、用户输入单元107、接口单元108、存储器109、处理器110、以及电源111等部件。本领域技术人员可以理解,图1中示出的移动终端结构并不构成对移动终端的限定,移动终端可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件布置。
下面结合图1对移动终端的各个部件进行具体的介绍:
射频单元101可用于收发信息或通话过程中,信号的接收和发送,具体的,将基站的下行信息接收后,给处理器110处理;另外,将上行的数据发送给基站。通常,射频单元101包括但不限于天线、至少一个放大器、收发信机、耦合器、低噪声放大器、双工器等。此外,射频单元101还可以通过无线通信与网络和其他设备通信。上述无线通信可以使用任一通信标准或协议,包括但不限于GSM(Global System of Mobile communication,全球移动通讯***)、GPRS(General Packet Radio Service,通用分组无线服务)、CDMA2000(CodeDivision Multiple Access 2000,码分多址2000)、WCDMA(Wideband Code DivisionMultiple Access,宽带码分多址)、TD-SCDMA(Time Division-Synchronous CodeDivision Multiple Access,时分同步码分多址)、FDD-LTE(Frequency DivisionDuplexing-Long Term Evolution,频分双工长期演进)和TDD-LTE(Time DivisionDuplexing-Long Term Evolution,分时双工长期演进)等。
WiFi属于短距离无线传输技术,移动终端通过WiFi模块102可以帮助用户收发电子邮件、浏览网页和访问流式媒体等,它为用户提供了无线的宽带互联网访问。虽然图1示出了WiFi模块102,但是可以理解的是,其并不属于移动终端的必须构成,完全可以根据需要在不改变发明的本质的范围内而省略。
音频输出单元103可以在移动终端100处于呼叫信号接收模式、通话模式、记录模式、语音识别模式、广播接收模式等等模式下时,将射频单元101或WiFi模块102接收的或者在存储器109中存储的音频数据转换成音频信号并且输出为声音。而且,音频输出单元103还可以提供与移动终端100执行的特定功能相关的音频输出(例如,呼叫信号接收声音、消息接收声音等等)。音频输出单元103可以包括扬声器、蜂鸣器等等。
A/V输入单元104用于接收音频或视频信号。A/V输入单元104可以包括图形处理器(Graphics Processing Unit,GPU)1041和麦克风1042,图形处理器1041对在视频捕获模式或图像捕获模式中由图像捕获装置(如摄像头)获得的静态图片或视频的图像数据进行处理。处理后的图像帧可以显示在显示单元106上。经图形处理器1041处理后的图像帧可以存储在存储器109(或其它存储介质)中或者经由射频单元101或WiFi模块102进行发送。麦克风1042可以在电话通话模式、记录模式、语音识别模式等等运行模式中经由麦克风1042接收声音(音频数据),并且能够将这样的声音处理为音频数据。处理后的音频(语音)数据可以在电话通话模式的情况下转换为可经由射频单元101发送到移动通信基站的格式输出。麦克风1042可以实施各种类型的噪声消除(或抑制)算法以消除(或抑制)在接收和发送音频信号的过程中产生的噪声或者干扰。
移动终端100还包括至少一种传感器105,比如光传感器、运动传感器以及其他传感器。具体地,光传感器包括环境光传感器及接近传感器,其中,环境光传感器可根据环境光线的明暗来调节显示面板1061的亮度,接近传感器可在移动终端100移动到耳边时,关闭显示面板1061和/或背光。作为运动传感器的一种,加速计传感器可检测各个方向上(一般为三轴)加速度的大小,静止时可检测出重力的大小及方向,可用于识别手机姿态的应用(比如横竖屏切换、相关游戏、磁力计姿态校准)、振动识别相关功能(比如计步器、敲击)等;至于手机还可配置的指纹传感器、压力传感器、虹膜传感器、分子传感器、陀螺仪、气压计、湿度计、温度计、红外线传感器等其他传感器,在此不再赘述。
显示单元106用于显示由用户输入的信息或提供给用户的信息。显示单元106可包括显示面板1061,可以采用液晶显示器(Liquid Crystal Display,LCD)、有机发光二极管(Organic Light-Emitting Diode,OLED)等形式来配置显示面板1061。
用户输入单元107可用于接收输入的数字或字符信息,以及产生与移动终端的用户设置以及功能控制有关的键信号输入。具体地,用户输入单元107可包括触控面板1071以及其他输入设备1072。触控面板1071,也称为触摸屏,可收集用户在其上或附近的触摸操作(比如用户使用手指、触笔等任何适合的物体或附件在触控面板1071上或在触控面板1071附近的操作),并根据预先设定的程式驱动相应的连接装置。触控面板1071可包括触摸检测装置和触摸控制器两个部分。其中,触摸检测装置检测用户的触摸方位,并检测触摸操作带来的信号,将信号传送给触摸控制器;触摸控制器从触摸检测装置上接收触摸信息,并将它转换成触点坐标,再送给处理器110,并能接收处理器110发来的命令并加以执行。此外,可以采用电阻式、电容式、红外线以及表面声波等多种类型实现触控面板1071。除了触控面板1071,用户输入单元107还可以包括其他输入设备1072。具体地,其他输入设备1072可以包括但不限于物理键盘、功能键(比如音量控制按键、开关按键等)、轨迹球、鼠标、操作杆等中的一种或多种,具体此处不做限定。
进一步的,触控面板1071可覆盖显示面板1061,当触控面板1071检测到在其上或附近的触摸操作后,传送给处理器110以确定触摸事件的类型,随后处理器110根据触摸事件的类型在显示面板1061上提供相应的视觉输出。虽然在图1中,触控面板1071与显示面板1061是作为两个独立的部件来实现移动终端的输入和输出功能,但是在某些实施例中,可以将触控面板1071与显示面板1061集成而实现移动终端的输入和输出功能,具体此处不做限定。
接口单元108用作至少一个外部装置与移动终端100连接可以通过的接口。例如,外部装置可以包括有线或无线头戴式耳机端口、外部电源(或电池充电器)端口、有线或无线数据端口、存储卡端口、用于连接具有识别模块的装置的端口、音频输入/输出(I/O)端口、视频I/O端口、耳机端口等等。接口单元108可以用于接收来自外部装置的输入(例如,数据信息、电力等等)并且将接收到的输入传输到移动终端100内的一个或多个元件或者可以用于在移动终端100和外部装置之间传输数据。
存储器109可用于存储软件程序以及各种数据。存储器109可主要包括存储程序区和存储数据区,其中,存储程序区可存储操作***、至少一个功能所需的应用程序(比如声音播放功能、图像播放功能等)等;存储数据区可存储根据手机的使用所创建的数据(比如音频数据、电话本等)等。此外,存储器109可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件、闪存器件、或其他易失性固态存储器件。
处理器110是移动终端的控制中心,利用各种接口和线路连接整个移动终端的各个部分,通过运行或执行存储在存储器109内的软件程序和/或模块,以及调用存储在存储器109内的数据,执行移动终端的各种功能和处理数据,从而对移动终端进行整体监控。处理器110可包括一个或多个处理单元;优选的,处理器110可集成应用处理器和调制解调处理器,其中,应用处理器主要处理操作***、用户界面和应用程序等,调制解调处理器主要处理无线通信。可以理解的是,上述调制解调处理器也可以不集成到处理器110中。
移动终端100还可以包括给各个部件供电的电源111(比如电池),优选的,电源111可以通过电源管理***与处理器110逻辑相连,从而通过电源管理***实现管理充电、放电、以及功耗管理等功能。
尽管图1未示出,移动终端100还可以包括蓝牙模块等,在此不再赘述。
为了便于理解本发明实施例,下面对本发明的移动终端所基于的通信网络***进行描述。
请参阅图2,图2为本发明实施例提供的一种通信网络***架构图,该通信网络***为通用移动通信技术的LTE***,该LTE***包括依次通讯连接的UE(User Equipment,用户设备)201,E-UTRAN(Evolved UMTS Terrestrial Radio Access Network,演进式UMTS陆地无线接入网)202,EPC(Evolved Packet Core,演进式分组核心网)203和运营商的IP业务204。
具体地,UE201可以是上述终端100,此处不再赘述。
E-UTRAN202包括eNodeB2021和其它eNodeB2022等。其中,eNodeB2021可以通过回程(backhaul)(例如X2接口)与其它eNodeB2022连接,eNodeB2021连接到EPC203,eNodeB2021可以提供UE201到EPC203的接入。
EPC203可以包括MME(Mobility Management Entity,移动性管理实体)2031,HSS(Home Subscriber Server,归属用户服务器)2032,其它MME2033,SGW(Serving Gate Way,服务网关)2034,PGW(PDN Gate Way,分组数据网络网关)2035和PCRF(Policy andCharging Rules Function,政策和资费功能实体)2036等。其中,MME2031是处理UE201和EPC203之间信令的控制节点,提供承载和连接管理。HSS2032用于提供一些寄存器来管理诸如归属位置寄存器(图中未示)之类的功能,并且保存有一些有关服务特征、数据速率等用户专用的信息。所有用户数据都可以通过SGW2034进行发送,PGW2035可以提供UE 201的IP地址分配以及其它功能,PCRF2036是业务数据流和IP承载资源的策略与计费控制策略决策点,它为策略与计费执行功能单元(图中未示)选择及提供可用的策略和计费控制决策。
IP业务204可以包括因特网、内联网、IMS(IP Multimedia Subsystem,IP多媒体子***)或其它IP业务等。
虽然上述以LTE***为例进行了介绍,但本领域技术人员应当知晓,本发明不仅仅适用于LTE***,也可以适用于其他无线通信***,例如GSM、CDMA2000、WCDMA、TD-SCDMA以及未来新的网络***等,此处不做限定。
基于上述移动终端硬件结构以及通信网络***,提出本发明方法各个实施例。
第一实施例
为了更好地理解本申请实施例,以下对有关技术进行说明:
MessageQueue通常翻译为“消息队列”,它内部存储了一组数据,以队列的形式对外提供***和删除操作。
Looper可以理解为消息循环,因为MessageQueue只是一个存储消息队列,不能去处理消息,所以需要Looper无限循环的去查看是否有新的消息,如果有的话就处理消息,否则就一直等待(阻塞)。
ANR一般有三种类型:按键或触摸事件在特定时间内(5s)无响应、BroadcastReceiver在特定时间内(10s)无法处理完成、Service在特定的时间内(20s)无法处理完成。
如图3所示,本申请第一实施例提供一种应用程序无响应阻塞的检测方法,该方法用于终端,所述应用程序无响应阻塞的检测方法包括:
步骤S31、在应用程序启动时启动监控线程,并通过所述监控线程每隔第一预设时间触发一次监控任务。
在本实施例中,所述监控线程为独立的、低优先级的守护进程且拥有自己的消息循环Looper。当所述监控线程启动之后,会运行在自己的独立环境不与其它进程交互,不会与其它进程相互干扰。
需要说明的是,第一预设时间通常较长,以按键或触摸事件在特定时间内(5s)无响应为例,第一预设时间可以设置为2.5s,即2500ms。由于监控线程执行监控任务的周期长达2.5s,所耗费的资源非常少,不会对应用程序造成负担。
步骤S32、在所述监控任务被触发的情况下,判断所述应用程序的主线程当前执行的任务与前一次监控任务被触发时所述主线程执行的任务是否相同。
在本实施例中,当一个应用程序运行过程中,通常需要同时运行多个线程。例如:在视频应用中,一个线程负责显示图像,一个线程负责播放声音,而只有多个线程同时工作才能确保用户在观看视频的同时听见声音。主线程的作用在于与用户进行信息交互,例如:用户点击屏幕上的按钮,该按钮做出反应。如果主线程阻塞,则用户将无法与应用程序进行交互,超过5秒便会发生ANR。
在本实施例中,当所述监控任务被触发时,通过判断所述应用程序的主线程当前执行的任务与前一次监控任务被触发时所述主线程执行的任务是否相同,确认所述应用程序的主线程是否发生阻塞。
在一种实施方式中,所述在所述监控任务被触发的情况下,判断所述应用程序的主线程当前执行的任务与前一次监控任务被触发时所述主线程执行的任务是否相同包括:
在所述监控任务被触发的情况下,通过所述监控线程获取所述主线程当前执行的任务的哈希代码值、前一次监控任务被触发时所述主线程执行的任务的哈希代码值;
将所述主线程当前执行的任务的哈希代码值与前一次监控任务被触发时所述主线程执行的任务的哈希代码值进行比较;
在所述主线程当前执行的任务的哈希代码值与前一次监控任务被触发时所述主线程执行的任务的哈希代码值相同的情况下,确定所述应用程序的主线程当前执行的任务与前一次监控任务被触发时所述主线程执行的任务相同。
在该实施方式中,当监控任务被触发后,监控线程会主动获取所述主线程当前执行的任务的hashCode值,然后将所述主线程当前执行的任务的hashCode值和前一次监控任务被触发时所述主线程执行的任务的hashCode值进行比较。如果两次的hashCode值相同,则证明所述主线程当前任务的执行总时间至少超过了所述第一预设时间,但是不能确认所述主线程在所述第一预设时间内是完全阻塞了。
由上述分析可知,监控任务只获取所述主线程执行的任务的hashCode值进行比较,所执行的任务非常简单,执行的时间也非常短。
步骤S33、在所述主线程当前执行的任务与前一次监控任务被触发时所述主线程执行的任务相同的情况下,判断第二预设时间前后的所述主线程的堆栈信息是否相同。
在本实施例中,应用程序在运行时都会生成对应的一个或者多个进程,而终端***会实时监测各应用程序对应的进程,如果***监测到了各应用程序对应的一个或多个进程出现故障,例如进程长时间对事件无响应或者执行耗时过长,则会生成堆栈信息。
由前述分析可知,当所述主线程当前执行的任务与前一次监控任务被触发时所述主线程执行的任务相同时,证明所述主线程当前任务的执行总时间至少超过了所述第一预设时间,但是不能确认所述主线程在所述第一预设时间内是完全阻塞了。因此,还需要通过判断第二预设时间前后的所述主线程的堆栈信息是否相同,再次确认所述主线程是否阻塞。
在一种实施方式中,所述在所述主线程当前执行的任务与前一次监控任务被触发时所述主线程执行的任务相同的情况下,判断第二预设时间前后的所述主线程的堆栈信息是否相同包括:
在所述主线程当前执行的任务与前一次监控任务被触发时所述主线程执行的任务相同的情况下,保存所述主线程的堆栈信息;
在所述第二预设时间之后,重新获取所述主线程的堆栈信息;
将保存的所述主线程的堆栈信息和重新获取的所述主线程的堆栈信息进行对比,根据对比结果确定所述第二预设时间前后所述主线程的堆栈信息是否相同。
在该实施方式中,当所述主线程当前执行的任务与前一次监控任务被触发时所述主线程执行的任务相同时,保存所述主线程的堆栈信息。在所述第二预设时间之后,再次获取所述主线程的堆栈信息。如果两次堆栈信息完全相同,可确认所述主线程发生阻塞。
步骤S34、在所述第二预设时间前后的所述主线程的堆栈信息相同的情况下,确定所述主线程发生阻塞。
在一种实施方式中,所述在所述第二预设时间前后的所述主线程的堆栈信息相同的情况下,确定所述主线程发生阻塞,之后还包括:
在确定所述主线程发生阻塞的情况下,打印日志信息;所述日志信息包括所述主线程的堆栈信息、以及所述主线程当前执行的任务的***时间。
在该实施方式中,若第一预设时间设置为2500ms,当所述主线程一次阻塞5s时,监控线程至少会打印一次所述主线程的堆栈信息。而用户通常所遇到的ANR信息基本都会超过5s,因此当所述主线程真正卡住时候,监控线程至少会打印两次所述主线程的堆栈信息,阻塞的时间越长打印的次数也会越多。当在解决ANR问题时候,可以根据多次打印出的堆栈信息推断出程序具体是阻塞在哪个地方。
在一种实施方式中,所述打印日志信息,之前还包括:
在确定所述主线程发生阻塞的情况下,获取所述主线程当前执行的任务的派遣时间;
将所述主线程当前执行的任务的派遣时间折算为所述主线程当前执行的任务的***时间。
在一种实施方式中,所述在所述第二预设时间前后的所述主线程的堆栈信息相同的情况下,确定所述主线程发生阻塞,之后还包括:
判断所述主线程发生阻塞的时长是否超过预设时长阈值;
在所述主线程发生阻塞的时长超过预设时长阈值的情况下,获取备份的恢复数据;
根据所述备份的恢复数据重新启动所述应用程序。
以按键或触摸事件在特定时间内(5s)无响应为例,当所述主线程发生阻塞的时长超过5s时,可通过无响应的应用程序的数据包名,查找之前是否备份过应用程序的恢复数据。若查找到备份的应用程序的恢复数据,则重新启动该应用程序。如果应用程序启动成功,则进一步,可以提示恢复到之前备份的数据。该提示信息可以通过显示屏以文字的方式提示,也可以通过扬声器以音频的方式提示,本实施例在此不作限定。
在另一种实施方式中,所述根据所述备份的恢复数据重新启动所述应用程序,之后还包括:
在根据所述备份的恢复数据重新启动所述应用程序失败的情况下,删除所述应用程序的数据,重新启动所述应用程序。
在该实施方式中,当应用程序启动失败时,通过重置应用程序数据来消除应用程序在无响应时产生的不必要的冗余数据,保证应用程序顺利重新启动,避免因应用程序无响应且无法重新启动时,必须重新安装而造成操作繁杂,影响用户正常使用的问题。
为了更好地阐述本申请实施例的应用程序无响应阻塞的检测过程,以下结合图4进行说明:
如图4所示,在应用程序启动时启动监控线程,监控线程每隔2500ms触发一次监控任务。
当监控任务触发后,监控线程会主动获取主线程队列当前正在执行的任务的hashCode值以及任务的派遣时间,并保存下来,然后将此次的hashCode值和前一次监控任务触发时获取的hashCode值相比较,如果两次的hashCode值相同则证明主线程当前的任务执行总时间至少超过了2.5s,但是不能确认主线程是完全阻塞了2.5s,所以现在保存好主线程的堆栈信息,10ms后再次通过确认主线程阻塞的方法确认主线程是否阻塞。
10ms后监控线程再一次获取主线程的堆栈信息和前面保存的主线程的堆栈信息相互对比,如果两次堆栈信息完全相同且派遣任务的时间到现在的时间大于2.5s,那么基本可以确认主线程在执行任务时候阻塞在堆栈信息所提示的地方。然后将派遣时间折算为***时间,最后将该时间和堆栈信息以警告类型的Log信息打印出来。
当主线程一次阻塞5s时,监控线程至少会打印一次主线程的堆栈信息。而用户通常所遇到的ANR信息基本都会超过5s,因此当主线程真正卡住时候,监控线程至少会打印两次主线程的堆栈信息,阻塞的时间越长打印的次数也会越多。当在解决ANR问题时候,可以根据多次打印出的堆栈信息推断出程序具体是阻塞在哪个地方。
本申请实施例的应用程序无响应阻塞的检测方法,通过在应用程序启动时启动监控线程,在任务相同、堆栈信息相同时确定主线程发生阻塞;解决了现有技术中ANR的排查方法存在操作复杂度较高、难以分析ANR发生原因的问题;使用简单,可精确定位到主线程阻塞位置,不耗费CPU和内存资源。
第二实施例
如图5所示,本申请第二实施例提供一种终端,所述终端包括存储器41、处理器42及存储在所述存储器41上并可在所述处理器42上运行的应用程序无响应阻塞的检测程序,所述应用程序无响应阻塞的检测程序被所述处理器42执行时,用于实现以下所述的应用程序无响应阻塞的检测方法的步骤:
在应用程序启动时启动监控线程,并通过所述监控线程每隔第一预设时间触发一次监控任务;
在所述监控任务被触发的情况下,判断所述应用程序的主线程当前执行的任务与前一次监控任务被触发时所述主线程执行的任务是否相同;
在所述主线程当前执行的任务与前一次监控任务被触发时所述主线程执行的任务相同的情况下,判断第二预设时间前后的所述主线程的堆栈信息是否相同;
在所述第二预设时间前后的所述主线程的堆栈信息相同的情况下,确定所述主线程发生阻塞。
所述应用程序无响应阻塞的检测程序被所述处理器42执行时,还用于实现以下所述的应用程序无响应阻塞的检测方法的步骤:
所述在所述监控任务被触发的情况下,判断所述应用程序的主线程当前执行的任务与前一次监控任务被触发时所述主线程执行的任务是否相同包括:
在所述监控任务被触发的情况下,通过所述监控线程获取所述主线程当前执行的任务的哈希代码值、前一次监控任务被触发时所述主线程执行的任务的哈希代码值;
将所述主线程当前执行的任务的哈希代码值与前一次监控任务被触发时所述主线程执行的任务的哈希代码值进行比较;
在所述主线程当前执行的任务的哈希代码值与前一次监控任务被触发时所述主线程执行的任务的哈希代码值相同的情况下,确定所述应用程序的主线程当前执行的任务与前一次监控任务被触发时所述主线程执行的任务相同。
所述应用程序无响应阻塞的检测程序被所述处理器42执行时,还用于实现以下所述的应用程序无响应阻塞的检测方法的步骤:
所述在所述主线程当前执行的任务与前一次监控任务被触发时所述主线程执行的任务相同的情况下,判断第二预设时间前后的所述主线程的堆栈信息是否相同包括:
在所述主线程当前执行的任务与前一次监控任务被触发时所述主线程执行的任务相同的情况下,保存所述主线程的堆栈信息;
在所述第二预设时间之后,重新获取所述主线程的堆栈信息;
将保存的所述主线程的堆栈信息和重新获取的所述主线程的堆栈信息进行对比,根据对比结果确定所述第二预设时间前后所述主线程的堆栈信息是否相同。
所述应用程序无响应阻塞的检测程序被所述处理器42执行时,还用于实现以下所述的应用程序无响应阻塞的检测方法的步骤:
所述在所述第二预设时间前后的所述主线程的堆栈信息相同的情况下,确定所述主线程发生阻塞,之后还包括:
在确定所述主线程发生阻塞的情况下,打印日志信息;所述日志信息包括所述主线程的堆栈信息、以及所述主线程当前执行的任务的***时间。
所述应用程序无响应阻塞的检测程序被所述处理器42执行时,还用于实现以下所述的应用程序无响应阻塞的检测方法的步骤:
所述打印日志信息,之前还包括:
在确定所述主线程发生阻塞的情况下,获取所述主线程当前执行的任务的派遣时间;
将所述主线程当前执行的任务的派遣时间折算为所述主线程当前执行的任务的***时间。
所述应用程序无响应阻塞的检测程序被所述处理器42执行时,还用于实现以下所述的应用程序无响应阻塞的检测方法的步骤:
所述在所述第二预设时间前后的所述主线程的堆栈信息相同的情况下,确定所述主线程发生阻塞,之后还包括:
判断所述主线程发生阻塞的时长是否超过预设时长阈值;
在所述主线程发生阻塞的时长超过预设时长阈值的情况下,获取备份的恢复数据;
根据所述备份的恢复数据重新启动所述应用程序。
所述应用程序无响应阻塞的检测程序被所述处理器42执行时,还用于实现以下所述的应用程序无响应阻塞的检测方法的步骤:
所述根据所述备份的恢复数据重新启动所述应用程序,之后还包括:
在根据所述备份的恢复数据重新启动所述应用程序失败的情况下,删除所述应用程序的数据,重新启动所述应用程序。
所述应用程序无响应阻塞的检测程序被所述处理器42执行时,还用于实现以下所述的应用程序无响应阻塞的检测方法的步骤:
所述监控线程为独立的、低优先级的守护进程且拥有自己的消息循环Looper。
本申请实施例的终端,通过在应用程序启动时启动监控线程,在任务相同、堆栈信息相同时确定主线程发生阻塞;解决了现有技术中ANR的排查方法存在操作复杂度较高、难以分析ANR发生原因的问题;使用简单,可精确定位到主线程阻塞位置,不耗费CPU和内存资源。
第三实施例
本申请第三实施例提供一种计算机可读存储介质,所述计算机可读存储介质上存储有应用程序无响应阻塞的检测程序,所述应用程序无响应阻塞的检测程序被处理器执行时用于实现第一实施例所述的应用程序无响应阻塞的检测方法的步骤。
需要说明的是,本实施例的计算机可读存储介质,与第一实施例的方法属于同一构思,其具体实现过程详细见方法实施例,且方法实施例中的技术特征在本实施例中均对应适用,这里不再赘述。
本申请实施例的计算机可读存储介质,通过在应用程序启动时启动监控线程,在任务相同、堆栈信息相同时确定主线程发生阻塞;解决了现有技术中ANR的排查方法存在操作复杂度较高、难以分析ANR发生原因的问题;使用简单,可精确定位到主线程阻塞位置,不耗费CPU和内存资源。
本领域普通技术人员可以理解,上文中所公开方法中的全部或某些步骤、***、装置中的功能模块/单元可以被实施为软件、固件、硬件及其适当的组合。在硬件实施方式中,在以上描述中提及的功能模块/单元之间的划分不一定对应于物理组件的划分;例如,一个物理组件可以具有多个功能,或者一个功能或步骤可以由若干物理组件合作执行。某些物理组件或所有物理组件可以被实施为由处理器,如中央处理器、数字信号处理器或微处理器执行的软件,或者被实施为硬件,或者被实施为集成电路,如专用集成电路。这样的软件可以分布在计算机可读介质上,计算机可读介质可以包括计算机存储介质(或非暂时性介质)和通信介质(或暂时性介质)。如本领域普通技术人员公知的,术语计算机存储介质包括在用于存储信息(诸如计算机可读指令、数据结构、程序模块或其他数据)的任何方法或技术中实施的易失性和非易失性、可移除和不可移除介质。计算机存储介质包括但不限于RAM、ROM、EEPROM、闪存或其他存储器技术、CD-ROM、数字多功能盘(DVD)或其他光盘存储、磁盒、磁带、磁盘存储或其他磁存储装置、或者可以用于存储期望的信息并且可以被计算机访问的任何其他的介质。此外,本领域普通技术人员公知的是,通信介质通常包含计算机可读指令、数据结构、程序模块或者诸如载波或其他传输机制之类的调制数据信号中的其他数据,并且可包括任何信息递送介质。
以上参照附图说明了本申请的优选实施例,并非因此局限本申请的权利范围。本领域技术人员不脱离本申请的范围和实质内所作的任何修改、等同替换和改进,均应在本申请的权利范围之内。
Claims (9)
1.一种应用程序无响应阻塞的检测方法,该方法用于终端,其特征在于,所述应用程序无响应阻塞的检测方法包括:
在应用程序启动时启动监控线程,并通过所述监控线程每隔第一预设时间触发一次监控任务;
在所述监控任务被触发的情况下,判断所述应用程序的主线程当前执行的任务与前一次监控任务被触发时所述主线程执行的任务是否相同;
在所述主线程当前执行的任务与前一次监控任务被触发时所述主线程执行的任务相同的情况下,判断第二预设时间前后的所述主线程的堆栈信息是否相同;
在所述第二预设时间前后的所述主线程的堆栈信息相同的情况下,确定所述主线程发生阻塞;
其中,所述在所述监控任务被触发的情况下,判断所述应用程序的主线程当前执行的任务与前一次监控任务被触发时所述主线程执行的任务是否相同包括:
在所述监控任务被触发的情况下,通过所述监控线程获取所述主线程当前执行的任务的哈希代码值、前一次监控任务被触发时所述主线程执行的任务的哈希代码值;
将所述主线程当前执行的任务的哈希代码值与前一次监控任务被触发时所述主线程执行的任务的哈希代码值进行比较;
在所述主线程当前执行的任务的哈希代码值与前一次监控任务被触发时所述主线程执行的任务的哈希代码值相同的情况下,确定所述应用程序的主线程当前执行的任务与前一次监控任务被触发时所述主线程执行的任务相同。
2.根据权利要求1所述的应用程序无响应阻塞的检测方法,其特征在于,所述在所述主线程当前执行的任务与前一次监控任务被触发时所述主线程执行的任务相同的情况下,判断第二预设时间前后的所述主线程的堆栈信息是否相同包括:
在所述主线程当前执行的任务与前一次监控任务被触发时所述主线程执行的任务相同的情况下,保存所述主线程的堆栈信息;
在所述第二预设时间之后,重新获取所述主线程的堆栈信息;
将保存的所述主线程的堆栈信息和重新获取的所述主线程的堆栈信息进行对比,根据对比结果确定所述第二预设时间前后所述主线程的堆栈信息是否相同。
3.根据权利要求1所述的应用程序无响应阻塞的检测方法,其特征在于,所述在所述第二预设时间前后的所述主线程的堆栈信息相同的情况下,确定所述主线程发生阻塞,之后还包括:
在确定所述主线程发生阻塞的情况下,打印日志信息;所述日志信息包括所述主线程的堆栈信息、以及所述主线程当前执行的任务的***时间。
4.根据权利要求3所述的应用程序无响应阻塞的检测方法,其特征在于,所述打印日志信息,之前还包括:
在确定所述主线程发生阻塞的情况下,获取所述主线程当前执行的任务的派遣时间;
将所述主线程当前执行的任务的派遣时间折算为所述主线程当前执行的任务的***时间。
5.根据权利要求1所述的应用程序无响应阻塞的检测方法,其特征在于,所述在所述第二预设时间前后的所述主线程的堆栈信息相同的情况下,确定所述主线程发生阻塞,之后还包括:
判断所述主线程发生阻塞的时长是否超过预设时长阈值;
在所述主线程发生阻塞的时长超过预设时长阈值的情况下,获取备份的恢复数据;
根据所述备份的恢复数据重新启动所述应用程序。
6.根据权利要求5所述的应用程序无响应阻塞的检测方法,其特征在于,所述根据所述备份的恢复数据重新启动所述应用程序,之后还包括:
在根据所述备份的恢复数据重新启动所述应用程序失败的情况下,删除所述应用程序的数据,重新启动所述应用程序。
7.根据权利要求1所述的应用程序无响应阻塞的检测方法,其特征在于,所述监控线程为独立的、低优先级的守护进程且拥有自己的消息循环Looper。
8.一种终端,其特征在于,所述终端包括存储器、处理器及存储在所述存储器上并可在所述处理器上运行的应用程序无响应阻塞的检测程序,所述应用程序无响应阻塞的检测程序被所述处理器执行时实现如权利要求1至7中任一项所述的应用程序无响应阻塞的检测方法的步骤。
9.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质上存储有应用程序无响应阻塞的检测程序,所述应用程序无响应阻塞的检测程序被处理器执行时实现如权利要求1至7中任一项所述的应用程序无响应阻塞的检测方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910441271.3A CN110188016B (zh) | 2019-05-24 | 2019-05-24 | 应用程序无响应阻塞的检测方法、终端以及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910441271.3A CN110188016B (zh) | 2019-05-24 | 2019-05-24 | 应用程序无响应阻塞的检测方法、终端以及存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN110188016A CN110188016A (zh) | 2019-08-30 |
CN110188016B true CN110188016B (zh) | 2022-11-01 |
Family
ID=67717756
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201910441271.3A Active CN110188016B (zh) | 2019-05-24 | 2019-05-24 | 应用程序无响应阻塞的检测方法、终端以及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN110188016B (zh) |
Families Citing this family (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110795669B (zh) * | 2019-10-28 | 2022-03-29 | 口碑(上海)信息技术有限公司 | 表单页面响应处理方法及装置 |
CN113297052B (zh) * | 2020-02-21 | 2024-04-26 | 腾讯科技(深圳)有限公司 | 应用程序的卡顿事件定位方法、装置、存储介质和设备 |
CN112546617B (zh) * | 2020-12-29 | 2022-08-30 | 珠海金山数字网络科技有限公司 | 任务处理方法及装置 |
CN113138883B (zh) * | 2021-05-14 | 2024-02-02 | 北京字节跳动网络技术有限公司 | 消息处理方法、装置、存储介质及电子设备 |
CN113742177A (zh) * | 2021-09-10 | 2021-12-03 | 掌阅科技股份有限公司 | 应用性能监测方法、电子设备及存储介质 |
CN114880159B (zh) * | 2022-07-13 | 2022-09-13 | 腾讯科技(深圳)有限公司 | 数据处理方法、装置、设备及存储介质 |
CN115080247B (zh) * | 2022-08-15 | 2022-11-04 | 科来网络技术股份有限公司 | 一种高可用线程池切换方法及装置 |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5233611A (en) * | 1990-08-20 | 1993-08-03 | International Business Machines Corporation | Automated function testing of application programs |
CN106598806A (zh) * | 2016-12-05 | 2017-04-26 | 北京金和网络股份有限公司 | 监控基于 iPhone 平台开发的手机 APP 卡顿的方法 |
CN107590015A (zh) * | 2017-09-11 | 2018-01-16 | 北京京东尚科信息技术有限公司 | 监测主线程的阻塞的方法和装置 |
CN107729207A (zh) * | 2017-09-15 | 2018-02-23 | 青岛海信电器股份有限公司 | 一种应用程序主线程的监控方法及装置 |
CN107741897A (zh) * | 2017-09-11 | 2018-02-27 | 广州市百果园信息技术有限公司 | 应用程序流畅度检测方法、装置及智能终端 |
CN108345524A (zh) * | 2017-01-22 | 2018-07-31 | 腾讯科技(深圳)有限公司 | 应用程序监控方法及应用程序监控装置 |
-
2019
- 2019-05-24 CN CN201910441271.3A patent/CN110188016B/zh active Active
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5233611A (en) * | 1990-08-20 | 1993-08-03 | International Business Machines Corporation | Automated function testing of application programs |
CN106598806A (zh) * | 2016-12-05 | 2017-04-26 | 北京金和网络股份有限公司 | 监控基于 iPhone 平台开发的手机 APP 卡顿的方法 |
CN108345524A (zh) * | 2017-01-22 | 2018-07-31 | 腾讯科技(深圳)有限公司 | 应用程序监控方法及应用程序监控装置 |
CN107590015A (zh) * | 2017-09-11 | 2018-01-16 | 北京京东尚科信息技术有限公司 | 监测主线程的阻塞的方法和装置 |
CN107741897A (zh) * | 2017-09-11 | 2018-02-27 | 广州市百果园信息技术有限公司 | 应用程序流畅度检测方法、装置及智能终端 |
CN107729207A (zh) * | 2017-09-15 | 2018-02-23 | 青岛海信电器股份有限公司 | 一种应用程序主线程的监控方法及装置 |
Also Published As
Publication number | Publication date |
---|---|
CN110188016A (zh) | 2019-08-30 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN110188016B (zh) | 应用程序无响应阻塞的检测方法、终端以及存储介质 | |
CN108900370B (zh) | 长连接多重超时判断方法、装置及计算机可读存储介质 | |
CN107357704B (zh) | 一种应用程序检测方法、终端及计算机可读存储介质 | |
CN108509299B (zh) | 消息处理方法、设备及计算机可读存储介质 | |
CN107592416B (zh) | 语音信息发送方法、终端及计算机可读存储介质 | |
CN110704217A (zh) | 一种内存泄露检测方法、终端及计算机可读存储介质 | |
US20210091845A1 (en) | Beam state detection method and terminal | |
CN107704132B (zh) | 终端冻屏的检测方法、终端和计算机可读存储介质 | |
CN109831359B (zh) | 一种数据网络连接状态的检测方法及其终端设备 | |
CN112631535A (zh) | 一种投屏反向控制方法及装置、移动终端、存储介质 | |
CN109766119B (zh) | 恢复分区升级方法、终端和计算机可读存储介质 | |
CN113067734B (zh) | 电子价签升级方法、电子价签***、电子终端及存储介质 | |
CN107908492B (zh) | 黑屏检测方法、移动终端及计算机可读存储介质 | |
CN107766222B (zh) | 黑屏检测方法、移动终端及计算机可读存储介质 | |
CN109309762B (zh) | 消息处理方法、装置、移动终端以及存储介质 | |
CN108629863B (zh) | 在应用程序中自动签到的方法、移动终端及可读存储介质 | |
CN107872367B (zh) | 黑屏检测方法、移动终端及计算机可读存储介质 | |
CN107832191B (zh) | 黑屏检测方法、移动终端及计算机可读存储介质 | |
CN107748633B (zh) | 终端冻屏的解决方法、终端和计算机可读存储介质 | |
CN107818036B (zh) | 黑屏检测方法、移动终端及计算机可读存储介质 | |
CN108255631B (zh) | 移动终端重启定位方法、移动终端及计算机可读存储介质 | |
CN110187934B (zh) | 应用控制方法、终端及计算机可读存储介质 | |
CN112395106A (zh) | 进程管理方法、移动终端以及计算机可读存储介质 | |
CN108364595B (zh) | 一种静电释放检测方法、移动终端及计算机可读存储介质 | |
CN107888411B (zh) | 黑屏检测方法、移动终端及计算机可读存储介质 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
TA01 | Transfer of patent application right |
Effective date of registration: 20221013 Address after: 252000 Room 3011-1, Building A1 and S4, Zhihuigu Industrial Base, the intersection of Hunan Road and East Outer Ring Road, Xuying Town, High tech Zone, Liaocheng City, Shandong Province Applicant after: Shandong Duoke Technology Co.,Ltd. Address before: 518000 6-8 / F, 10-11 / F, 6 / F, 6-10 / F, C zone, Han's innovation building, No. 9018, Beihuan Avenue, high tech Zone, Nanshan District, Shenzhen City, Guangdong Province Applicant before: NUBIA TECHNOLOGY Co.,Ltd. |
|
TA01 | Transfer of patent application right | ||
GR01 | Patent grant | ||
GR01 | Patent grant |