CN113568801B - 冻屏检测方法、装置、终端设备及计算机存储介质 - Google Patents
冻屏检测方法、装置、终端设备及计算机存储介质 Download PDFInfo
- Publication number
- CN113568801B CN113568801B CN202010354202.1A CN202010354202A CN113568801B CN 113568801 B CN113568801 B CN 113568801B CN 202010354202 A CN202010354202 A CN 202010354202A CN 113568801 B CN113568801 B CN 113568801B
- Authority
- CN
- China
- Prior art keywords
- message
- main thread
- processed
- input event
- execution
- 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
- 238000001514 detection method Methods 0.000 title claims abstract description 56
- 238000012545 processing Methods 0.000 claims abstract description 84
- 230000001360 synchronised effect Effects 0.000 claims abstract description 10
- 238000000034 method Methods 0.000 claims description 37
- 238000012544 monitoring process Methods 0.000 claims description 31
- 238000004590 computer program Methods 0.000 claims description 23
- 238000011084 recovery Methods 0.000 claims description 16
- 230000001960 triggered effect Effects 0.000 claims description 4
- 230000000903 blocking effect Effects 0.000 abstract description 25
- 230000008569 process Effects 0.000 description 18
- 230000006870 function Effects 0.000 description 11
- 238000010586 diagram Methods 0.000 description 8
- 238000004891 communication Methods 0.000 description 5
- 238000009877 rendering Methods 0.000 description 5
- 230000004044 response Effects 0.000 description 4
- 230000008878 coupling Effects 0.000 description 3
- 238000010168 coupling process Methods 0.000 description 3
- 238000005859 coupling reaction Methods 0.000 description 3
- 238000005457 optimization Methods 0.000 description 3
- 230000003190 augmentative effect Effects 0.000 description 2
- 230000007246 mechanism Effects 0.000 description 2
- 230000009471 action Effects 0.000 description 1
- 230000002411 adverse Effects 0.000 description 1
- 238000003491 array Methods 0.000 description 1
- 230000009286 beneficial effect Effects 0.000 description 1
- 230000001413 cellular effect Effects 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 230000000977 initiatory effect Effects 0.000 description 1
- 230000003993 interaction Effects 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 230000006855 networking Effects 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
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
-
- 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
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/3089—Monitoring arrangements determined by the means or processing involved in sensing the monitored data, e.g. interfaces, connectors, sensors, probes, agents
- G06F11/3093—Configuration details thereof, e.g. installation, enabling, spatial arrangement of the probes
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- Quality & Reliability (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Computing Systems (AREA)
- Mathematical Physics (AREA)
- User Interface Of Digital Computer (AREA)
- Debugging And Monitoring (AREA)
Abstract
本申请适用于数据处理技术领域,提供了一种冻屏检测方法、装置、终端设备及计算机存储介质。在本申请提供的冻屏故障检测方法中,对主线程中待处理的消息的处理时长进行监测,当监测到待处理的消息的处理时长大于或等于预设时长阈值时,查看与该主线程连接的输入事件管道以及该主线程的消息队列。如果该输入事件管道中存在用户输入事件或者该消息队列中存在垂直同步信号,则表示发生了用户可感知的冻屏故障,记录冻屏故障日志。本申请提供的冻屏故障日志可以根据用户输入事件以及垂直同步信号判断当前主线程的消息阻塞故障是否是用户可感知的,从而准确识别冻屏故障,解决了现有的冻屏检测方案存在准确性低,容易影响用户的使用体验的问题。
Description
技术领域
本申请属于数据处理技术领域,尤其涉及一种冻屏检测方法、装置、终端设备及计算机存储介质。
背景技术
冻屏,是指终端设备在一定时间内无法响应用户的控制操作。目前出现冻屏故障的原因主要有两种,一种是***问题,另一种为应用程序自身的问题。
当应用程序的主线程存在消息拥挤、阻塞故障时,可能存在冻屏故障。此时,整个***是正常的,只有故障应用程序的界面卡住不动。
当终端设备出现冻屏故障时,会对极度影响用户的使用体验。因此,当前存在一些检测应用程序主线程状态的方案,当终端设备通过这些方案检测到应用程序的主线程存在消息堵塞情况时,就判定出现冻屏故障,指示终端设备执行相应的应用恢复操作。
但是,上述冻屏检测方***性低,容易将非冻屏故障误识别为冻屏故障,从而使终端设备误执行应用恢复操作,影响用户的使用体验。
发明内容
有鉴于此,本申请实施例提供了一种冻屏检测方法、装置、终端设备及计算机存储介质,以解决现有的冻屏检测方案存在准确性低,容易影响用户的使用体验的问题。
本申请实施例的第一方面提供了一种冻屏检测方法,包括:
监测主线程中待处理的消息的处理时长;
若所述待处理的消息的处理时长大于或等于预设时长阈值,且与所述主线程连接的输入事件管道中存在用户输入事件或所述主线程的消息队列中存在垂直同步信号,则判定发生冻屏故障,记录冻屏故障日志。
需要说明的是,当待处理的消息的处理时长大于或等于预设时长阈值时,表示主线程发生了消息阻塞故障。但是,主线程发生消息阻塞故障不一定表示发生冻屏故障。
因此,终端设备还可以检测与该主线程连接的事件输入管道。输入事件管道中的用户输入事件需要由主线程进行处理和响应。
当主线程发生消息阻塞故障时,如果终端设备检测到与该主线程连接的输入事件管道中存在用户输入事件,则表示主线程无法及时处理该用户输入事件,导致主线程对应的应用程序无法及时响应用户的操作,用户可以感知到该应用程序出现卡顿,此时,终端设备可以判定发生了冻屏故障,记录冻屏故障日志。
在第一方面的一种可能的实现方式中,所述处理时长包括驻留时长;
所述监测主线程中待处理的消息的处理时长包括:
获取所述待处理的消息进入所述主线程的消息队列的第一时间以及所述待处理的消息离开所述消息队列的第二时间;
根据所述第一时间和所述第二时间计算所述待处理的消息的驻留时长;
所述若所述待处理的消息的处理时长大于或等于预设时长阈值,且与所述主线程连接的输入事件管道中存在用户输入事件或所述主线程的消息队列中存在垂直同步信号,则判定发生冻屏故障,记录冻屏故障日志包括:
若所述待处理的消息的驻留时长大于或等于预设驻留阈值,且与所述主线程连接的输入事件管道中存在用户输入事件或所述主线程的消息队列中存在垂直同步信号,则判定发生冻屏故障,抓取所述主线程的堆栈信息,并将抓取到的堆栈信息记录为第一冻屏故障日志。
需要说明的是,待处理的消息的处理时长可以包括驻留时长。当待处理的消息的驻留时长大于或等于预设驻留阈值时,表示主线程因为积压了太多待处理的消息导致消息阻塞故障。
此时,如果终端设备检测到与该主线程连接的输入事件管道中存在用户输入事件,则表示主线程无法及时处理该用户输入事件,导致主线程对应的应用程序无法及时响应用户的操作,用户可以感知到该应用程序出现卡顿,此时,终端设备可以判定发生了冻屏故障,记录第一冻屏故障日志。
在第一方面的一种可能的实现方式中,所述处理时长包括执行时长;
所述监测主线程中待处理的消息的处理时长包括:
当所述待处理的消息离开所述消息队列时,对所述待处理的消息的执行时长进行计时;
所述若所述待处理的消息的处理时长大于或等于预设时长阈值,且与所述主线程连接的输入事件管道中存在用户输入事件或所述主线程的消息队列中存在垂直同步信号,则判定发生冻屏故障,记录冻屏故障日志包括:
当所述待处理的消息的执行时长大于或等于预设执行阈值时,若未检测到所述待处理的消息的执行完成信号且与所述主线程连接的输入事件管道中存在用户输入事件或所述主线程的消息队列中存在垂直同步信号,则判定发生冻屏故障,抓取所述主线程的堆栈信息,并将抓取到的堆栈信息记录为第二冻屏故障日志。
需要说明的是,待处理的消息的处理时长可以包括执行时长。当待处理的消息的执行时长大于或等于预设时长阈值时,表示主线程因为该待处理的消息的执行时长过长导致消息阻塞故障。
此时,如果终端设备检测到与该主线程连接的输入事件管道中存在用户输入事件,则表示主线程无法及时处理该用户输入事件,导致主线程对应的应用程序无法及时响应用户的操作,用户可以感知到该应用程序出现卡顿,此时,终端设备可以判定发生了冻屏故障,记录第二冻屏故障日志。
在第一方面的一种可能的实现方式中,所述当所述待处理的消息的执行时长大于或等于预设执行阈值时,若未检测到所述待处理的消息的执行完成信号且与所述主线程连接的输入事件管道中存在用户输入事件或所述主线程的消息队列中存在垂直同步信号,则判定发生冻屏故障,抓取所述主线程的堆栈信息,并将抓取到信息记录为第二冻屏故障日志包括:
当所述待处理的消息的执行时长大于或等于第一预设执行阈值时,若未检测到所述待处理的消息的执行完成信号,则抓取所述主线程的堆栈信息,存储抓取到的堆栈信息;
当所述待处理的消息的执行时长大于或等于第二预设执行阈值时,若未检测到所述待处理的消息的执行完成信号且与所述主线程连接的输入事件管道中存在用户输入事件或所述主线程的消息队列中存在垂直同步信号,则判定发生冻屏故障,将所述抓取到的堆栈信息记录为第二冻屏故障日志,其中,所述第一预设执行阈值小于所述第二预设执行阈值。
需要说明的是,终端设备在设置了第一预设执行阈值和第二执行阈值之后,可以在待处理的消息的执行时长大于或等于第一预设执行阈值时提前抓取主线程的堆栈信息,提前抓取主线程的堆栈信息可以确保该堆栈信息为冻屏故障现场的堆栈信息,从而确保生成的第二冻屏故障日志的准确性。
在第一方面的一种可能的实现方式中,所述方法还包括:
若接收到所述待处理的消息的执行完成信号时,所述待处理的消息的执行时长大于或等于所述第一预设执行阈值,且小于所述第二预设执行阈值,则将所述抓取到的堆栈信息记录为卡顿故障日志。
需要说明的是,如果某一待处理的消息的执行时长大于或等于第一预设执行阈值,且小于第二预设执行阈值,表示该待处理的消息的执行时长较长,虽然未引起冻屏故障,但是需要警惕。此时,终端设备可以将预先抓取到的堆栈信息记录为卡顿故障日志,以便开发人员根据卡顿故障日志进行优化调整。
在第一方面的一种可能的实现方式中,所述监测主线程中待处理的消息的处理时长包括:
通过与所述主线程独立的第一线程监测主线程中待处理的消息的处理时长。
需要说明的是,终端设备可以使用第一线程监测主线程中各个待处理的消息的处理时长。主线程和第一线程相互独立,从而确保在主线程在发生消息阻塞故障时,不会影响到第一线程的监测结果。
在第一方面的一种可能的实现方式中,在所述判定发生冻屏故障之后,还包括:
对所述主线程对应的应用程序执行预设应用恢复操作。
需要说明的是,当终端设备中设置有预设应用恢复操作时,终端设备可以在检测到冻屏故障后,对发生冻屏故障的应用程序执行预设应用恢复操作。
例如,终端设备发现某一应用程序发生了冻屏故障,终端设备可以重启该应用程序。
本申请实施例的第二方面提供了一种冻屏检测装置,包括:
时长监测模块,用于监测主线程中待处理的消息的处理时长;
冻屏检测模块,用于若所述待处理的消息的处理时长大于或等于预设时长阈值,且与所述主线程连接的输入事件管道中存在用户输入事件或所述主线程的消息队列中存在垂直同步信号,则判定发生冻屏故障,记录冻屏故障日志。
在第二方面的一种可能的实现方式中,所述处理时长包括驻留时长;
所述时长监测模块包括:
时间获取子模块,用于获取所述待处理的消息进入所述主线程的消息队列的第一时间以及所述待处理的消息离开所述消息队列的第二时间;
驻留时长子模块,用于根据所述第一时间和所述第二时间计算所述待处理的消息的驻留时长;
所述冻屏检测模块包括:
第一冻屏子模块,用于若所述待处理的消息的驻留时长大于或等于预设驻留阈值,且与所述主线程连接的输入事件管道中存在用户输入事件或所述主线程的消息队列中存在垂直同步信号,则判定发生冻屏故障,抓取所述主线程的堆栈信息,并将抓取到的堆栈信息记录为第一冻屏故障日志。
在第二方面的一种可能的实现方式中,所述处理时长包括执行时长;
所述时长监测模块包括:
执行计时子模块,用于当所述待处理的消息离开所述消息队列时,对所述待处理的消息的执行时长进行计时;
所述冻屏检测模块包括:
第二冻屏子模块,用于当所述待处理的消息的执行时长大于或等于预设执行阈值时,若未检测到所述待处理的消息的执行完成信号且与所述主线程连接的输入事件管道中存在用户输入事件或所述主线程的消息队列中存在垂直同步信号,则判定发生冻屏故障,抓取所述主线程的堆栈信息,并将抓取到的堆栈信息记录为第二冻屏故障日志。
在第二方面的一种可能的实现方式中,所述第二冻屏子模块包括:
信息抓取子模块,用于当所述待处理的消息的执行时长大于或等于第一预设执行阈值时,若未检测到所述待处理的消息的执行完成信号,则抓取所述主线程的堆栈信息,存储抓取到的堆栈信息;
冻屏判定子模块,用于当所述待处理的消息的执行时长大于或等于第二预设执行阈值时,若未检测到所述待处理的消息的执行完成信号且与所述主线程连接的输入事件管道中存在用户输入事件或所述主线程的消息队列中存在垂直同步信号,则判定发生冻屏故障,将所述抓取到的堆栈信息记录为第二冻屏故障日志,其中,所述第一预设执行阈值小于所述第二预设执行阈值。
在第二方面的一种可能的实现方式中,所述第二冻屏子模块还包括:
卡顿判定子模块,用于若接收到所述待处理的消息的执行完成信号时,所述待处理的消息的执行时长大于或等于所述第一预设执行阈值,且小于所述第二预设执行阈值,则将所述抓取到的堆栈信息记录为卡顿故障日志。
在第二方面的一种可能的实现方式中,所述时长监测模块,具体用于通过与所述主线程独立的第一线程监测主线程中待处理的消息的处理时长。
在第二方面的一种可能的实现方式中,所述装置还包括:
应用恢复模块,用于对所述主线程对应的应用程序执行预设应用恢复操作。
本申请实施例的第三方面提供了一种终端设备,包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时,使得终端设备实现如上述方法的步骤。
本申请实施例的第四方面提供了一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,所述计算机程序被处理器执行时,使得终端设备实现如上述方法的步骤。
本申请实施例的第五方面提供了一种计算机程序产品,当计算机程序产品在终端设备上运行时,使得终端设备实现如上述方法的步骤。
本申请实施例与现有技术相比存在的有益效果是:
在本申请的冻屏检测方法中,对应用程序的主线程中的消息的处理时长进行监测。如果存在处理时长大于或等于预设时长阈值的消息,则表示该消息的处理时长超时。此时,并不直接判定存在冻屏故障,而是查询输入事件管道以及主线程的消息队列。如果输入事件管道中存在与该主线程关联的用户输入事件或者主线程的消息队列中存在垂直同步信号,则表示存在应用程序未响应的用户操作,用户可以感知到该应用程序的界面被卡住,此时,终端设备才判定存在冻屏故障。
在判定冻屏故障的过程中,结合用户输入事件以及垂直同步信号,可以得知用户是否可以感知到该消息的处理时长超时,针对性地判断是否存在冻屏故障,从而提高检测冻屏故障的准确性,避免将一些用户无法感知的消息处理超时情况判定为冻屏故障,解决了现有的冻屏检测方案存在准确性低,容易影响用户的使用体验的问题。
附图说明
为了更清楚地说明本申请实施例中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本申请的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动性的前提下,还可以根据这些附图获得其他的附图。
图1是本申请实施例提供的一种***架构图;
图2是本申请实施例提供的一种冻屏检测方法的流程示意图;
图3是本申请实施例提供的一种消息处理时间线的示意图;
图4是本申请实施例提供的另一种消息处理时间线的示意图;
图5是本申请实施例提供的一种应用场景的示意图;
图6是本申请实施例提供的另一种应用场景的示意图;
图7是本申请实施例提供的一种冻屏检测装置的结构示意图;
图8是本申请实施例提供的终端设备的结构示意图。
具体实施方式
以下描述中,为了说明而不是为了限定,提出了诸如特定***结构、技术之类的具体细节,以便透彻理解本申请实施例。然而,本领域的技术人员应当清楚,在没有这些具体细节的其它实施例中也可以实现本申请。在其它情况中,省略对众所周知的***、装置、电路以及方法的详细说明,以免不必要的细节妨碍本申请的描述。
应当理解,当在本申请说明书和所附权利要求书中使用时,术语“包括”指示所描述特征、整体、步骤、操作、元素和/或组件的存在,但并不排除一个或多个其它特征、整体、步骤、操作、元素、组件和/或其集合的存在或添加。
还应当理解,在本申请说明书和所附权利要求书中使用的术语“和/或”是指相关联列出的项中的一个或多个的任何组合以及所有可能组合,并且包括这些组合。
如在本申请说明书和所附权利要求书中所使用的那样,术语“如果”可以依据上下文被解释为“当...时”或“一旦”或“响应于确定”或“响应于检测到”。类似地,短语“如果确定”或“如果检测到[所描述条件或事件]”可以依据上下文被解释为意指“一旦确定”或“响应于确定”或“一旦检测到[所描述条件或事件]”或“响应于检测到[所描述条件或事件]”。
另外,在本申请说明书和所附权利要求书的描述中,术语“第一”、“第二”、“第三”等仅用于区分描述,而不能理解为指示或暗示相对重要性。
在本申请说明书中描述的参考“一个实施例”或“一些实施例”等意味着在本申请的一个或多个实施例中包括结合该实施例描述的特定特征、结构或特点。由此,在本说明书中的不同之处出现的语句“在一个实施例中”、“在一些实施例中”、“在其他一些实施例中”、“在另外一些实施例中”等不是必然都参考相同的实施例,而是意味着“一个或多个但不是所有的实施例”,除非是以其他方式另外特别强调。术语“包括”、“包含”、“具有”及它们的变形都意味着“包括但不限于”,除非是以其他方式另外特别强调。
本申请实施例提供的冻屏检测方法可以应用于手机、平板电脑、可穿戴设备、车载设备、增强现实(augmented reality,AR)/虚拟现实(virtual reality,VR)设备、笔记本电脑、超级移动个人计算机(ultra-mobile personal computer,UMPC)、上网本、个人数字助理(personal digital assistant,PDA)等终端设备上,本申请实施例对终端设备的具体类型不作任何限制。
例如,所述终端设备可以是WLAN中的站点(STAION,ST),可以是蜂窝电话、无绳电话、会话启动协议(Session InitiationProtocol,SIP)电话、无线本地环路(WirelessLocal Loop,WLL)站、个人数字处理(Personal Digital Assistant,PDA)设备、具有无线通信功能的手持设备、计算设备或连接到无线调制解调器的其它处理设备、车载设备、车联网终端、电脑、膝上型计算机、手持式通信设备、手持式计算设备、卫星无线设备、无线调制解调器卡、电视机顶盒(set top box,STB)、智能电视、用户驻地设备(customer premiseequipment,CPE)和/或用于在无线***上进行通信的其它设备以及下一代通信***,例如,5G网络中的移动终端或者未来演进的公共陆地移动网络(Public Land Mobile Network,PLMN)网络中的移动终端等。
冻屏,是指终端设备在一定时间内无法响应用户的控制操作。目前出现冻屏故障的原因主要有两种,一种是***问题,另一种为应用程序自身的问题。
当应用程序的主线程存在消息拥挤、阻塞故障时,可能存在冻屏故障。此时,整个***是正常的,只有故障应用程序的界面卡住不动。
当终端设备出现冻屏故障时,会极度影响用户的使用体验。当前的冻屏检测技术主要有程序未响应(Application Not Responding,ANR)检测技术和乒乓(Ping/Pong)检测机制。
在ANR检测技术中,终端设备从***监测应用程序是否超时响应,应用程序超时响应后,终端设备再对应用程序的主线程进行抓栈处理,将抓取到的堆栈信息记录为冻屏故障日志。
在Ping/Pong检测机制,终端设备启动一个独立线程,该独立线程定时向应用程序的主线程发送Ping消息,主线程接收到Ping消息后返回Pong消息至上述独立线程。如果主线程未能按时返回Pong消息,则认为主线程存在阻塞,对主线程进行抓栈处理,将抓取到的堆栈信息记录为冻屏故障日志。
上述冻屏检测方案均是用于检测应用程序的主线程是否发生阻塞。一旦应用程序的主线程发生阻塞,则认为发生冻屏故障。但是,当应用程序的主线程出现消息阻塞情况时,有可能是应用程序的底层操作卡顿,不一定会出现应用程序的界面被卡住的情况。当应用程序的底层操作卡顿时,用户是无感知的,不会影响用户的使用体验。
此时,如果终端设备贸然执行应用恢复操作,例如重启应用程序等,反而会影响用户的使用体验。
有鉴于此,本申请实施例提供了一种冻屏检测方法、装置、终端设备及计算机存储介质,以解决现有的冻屏检测方案存在准确性低,容易影响用户的使用体验的问题。
请参阅图1,图1是本申请实施例适用的一种终端设备的***架构图。终端设备的***架构可以包括:输入子***101、主线程102以及输入事件管道103。
上述输入子***101、主线程102以及输入事件管道103均为终端设备的软件架构。
其中,输入子***101用于接收各类用户输入事件,并将用户输入事件分发至相应的模块进行处理。上述用户输入事件可以是用户操作终端设备的硬件触发的事件,例如,用户点击终端设备的屏幕触发用户输入事件。
终端设备内部可能设置有一个或多个应用程序。当应用程序被启动时,终端设备的操作***会创建该应用程序的主线程102,该主线程102用于处理与该应用程序相关的各类消息。
当输入子***101需要将用户输入事件分发至应用程序进行处理时,输入子***101会创建与该应用程序的主线程102连接的输入事件管道103,输入子***101通过输入事件管道103将用户输入事件分发至应用程序的主线程102。其中,一条输入事件管道103只与一个应用程序的主线程102连接,输入子***101与某一个主线程102之间,可能存在一条或多条输入事件管道103。
本申请以下实施例主要以图1所示的架构场景为例,对本申请实施例提供的冻屏检测方法进行阐述。参见图2,该方法可以包括:
S201、监测主线程中待处理的消息的处理时长;
当终端设备需要检测冻屏故障时,终端设备可以监测应用程序的主线程中各个待处理的消息的处理时长。
终端设备监测主线程的方式可以根据实际需求进行选择。在一些实施例中,终端设备可以启用第一线程,通过第一线程监测主线程中待处理的消息的处理时长。
第一线程与应用程序的主线程相互独立,从而避免应用程序的主线程发生消息阻塞故障时影响第一线程的监测结果。
S202、若所述待处理的消息的处理时长大于或等于预设时长阈值,且与所述主线程连接的输入事件管道中存在用户输入事件或所述主线程的消息队列中存在垂直同步信号,则判定发生冻屏故障,记录冻屏故障日志。
终端设备在对各个待处理消息的处理时长进行监测时,如果发现任一待处理的消息的处理时长大于或等于预设时长阈值,则表示主线程可能发生了消息阻塞故障。此时,终端设备可以查看与该主线程连接的输入事件管道中是否存在用户输入事件,以及查看该主线程的消息队列中是否存在垂直同步(vsync)信号。
输入子***将用户输入事件分发至各输入事件管道,等待与输入事件管道连接的主线程获取输入事件管道中的用户输入事件并处理。
其中,用户输入事件是用户对终端设备进行操作而触发的事件。例如,当用户在玩游戏时,用户点击终端设备的屏幕,终端设备的传感器检测到用户的点击操作,生成与点击操作相对应的用户输入事件,输入子***将该用户输入事件分发至游戏应用程序的主线程,由该游戏应用程序的主线程对该用户输入事件进行处理,响应用户的点击操作。
vsync信号是由终端设备内部的硬件或软件定时生成的,vsync信号生成后,终端设备的显示子***会将vsync信号分发至相应的应用程序的主线程的消息队列,由该应用程序的主线程进行处理。vsync信号用于协调帧率和屏幕刷新频率。帧率为终端设备内图形渲染组件生成图像帧的速率,屏幕刷新频率是指终端设备刷新屏幕的频率。通常帧率和屏幕刷新频率难以保持一致,容易使终端设备显示的画面出现撕裂的情况。因此,终端设备可以通过垂直同步功能定时触发vsync信号,通过vsync信号控制图形渲染组件进行图形渲染的时间以及屏幕刷新的时间,从而使帧率和屏幕刷新屏幕保持一致。例如,当用户在玩游戏时开启了终端设备的垂直同步功能,将帧率和刷新频率控制在60Hz,则每隔1/60秒终端设备会触发一次垂直同步信号以指示图形渲染组件进行图形渲染以及屏幕刷新,从而确保帧率和屏幕刷新频率保持在60Hz。
输入事件管道中的用户输入事件以及主线程的消息队列中的vsync信号需要由主线程进行处理和响应。因此,当主线程发生消息阻塞故障时,如果终端设备检测到与该主线程连接的输入事件管道中存在用户输入事件或主线程的消息队列中存在vsync信号,则表示主线程无法及时处理该用户输入事件和/或vsync信号,导致该应用程序无法及时响应用户的操作以及刷新该应用程序的显示界面,用户可以感知到该应用程序出现卡顿,此时,终端设备可以判定发生了冻屏故障,记录冻屏故障日志。
例如,用户在使用手机玩游戏,开启了垂直同步功能。在某一时刻,终端设备检测到主线程中某一消息的处理时长大于预设时长阈值,并且与主线程的消息队列中存在vsync信号未处理,则表示终端设备不能及时处理该vsync信号,不能及时刷新该游戏应用的游戏画面,导致游戏画面被卡住,用户可以直接感知到该应用程序发生了卡顿。此时,终端设备可以判定发生了冻屏故障,记录冻屏故障日志。
如果在主线程发生消息阻塞故障时,终端设备检测到与该主线程连接的输入事件管道不存在用户输入事件且主线程的消息队列中不存在vsync信号,则表示用户所有的操作均已得到响应,即使主线程发生了发生消息阻塞故障,用户也是无感知的。由于冻屏的定义是指终端设备在一定时间内无法响应用户的控制操作,因此,在用户无法感知到应用程序发生了卡顿的情况下,应当判定未发生冻屏故障。
例如,用户在使用某个应用程序时,在某一时刻,该应用程序的主线程发生消息阻塞故障。但是,此时主线程的消息队列中只有一些底层操作的消息未处理,无vsync信号,且与该主线程连接的输入事件管道中无用户输入事件,则表示该应用程序已经刷新了上一帧的显示界面,且无未回应的用户操作。此时,虽然主线程发生了消息阻塞故障,但是用户无法感知,根据冻屏故障的定义,应当判定未发生冻屏故障。
在本实施例的冻屏检测方法中,在判定应用程序是否冻屏故障时,会对输入事件管道以及主线程的消息队列进行检测,根据输入事件管道中是否存在用户输入事件以及消息队列中是否存在vsync信号确认用户是否可以感知到该应用程序的主线程发生消息阻塞故障,针对性地判断是否存在冻屏故障,从而提高检测冻屏故障的准确性,避免将一些用户无法感知的主线程的消息阻塞故障判定为冻屏故障,解决了现有的冻屏检测方案存在准确性低,容易影响用户的使用体验的问题。
此外,上述描述的待处理的消息的处理时长可以根据实际情况进行定义。
在一种可能的实现方式中,上述处理时长可以为待处理的消息进入主线程的消息队列的时间点至该消息处理完成的时间点之间的时间间隔。
在这种情况下,终端设备在进行冻屏检测时,可以检测出主线程是否发生消息阻塞故障。但是,终端设备无法进一步确认上述消息阻塞故障是因为主线程中待处理的消息过多引起的,还是由于某个待处理的消息处理超时引起的。
因此,在另一种可能实现方式,终端设备可以将上述处理时长划分为驻留时长和执行时长。驻留时长表示待处理的消息在主线程的消息队列中驻留的时间。
终端设备可以获取待处理的消息进入主线程的消息队列的第一时间以及待处理的消息离开消息队列的第二时间,根据第一时间和第二时间计算待处理的消息的驻留时长。
例如,主线程可以在待处理的消息进入消息队列时,发送第一信号给第一线程,第一线程根据第一信号确定该待处理的消息进入消息队列的第一时间;当该待处理的消息离开消息队列时,主线程可以发送第二信号给第一线程,第一线程根据第二信号确定该待处理的消息离开消息队列的第二时间;然后第一线程用第二时间减去第一时间,得到该待处理消息的驻留时长。
如果终端设备检测到任一待处理的消息的驻留时长大于或等于预设驻留阈值,则表示此时主线程因为积压了大量的待处理的消息引起了消息阻塞故障。此时,终端设备可以查询与主线程连接的输入事件管道中是否存在用户输入事件以及消息队列中是否存在vsync信号。
如果终端设备检测到与主线程连接的输入事件管道中存在用户输入事件或消息队列中存在vsync信号,则判定发生冻屏故障,终端设备抓取主线程的堆栈信息,将抓取到的堆栈信息记录为第一冻屏故障日志。
如果终端设备检测到与主线程连接的输入事件管道中不存在用户输入事件且消息队列中不存在vsync信号,则判定未发生冻屏故障。
执行时长表示待处理的消息离开消息队列的时间至该消息被处理完成的时间。
当待处理的消息离开主线程的消息队列时,终端设备对该待处理的消息的执行时长进行计时,直至接收到该待处理消息的执行完成信号,停止计时。
例如,主线程可以在待处理的消息离开消息队列时,发送第二信号给第一线程,第一线程根据第二信号开始对该消息的执行时长进行计时;在该消息处理完成后,主线程发送执行完成信号给第一线程,第一线程停止对该消息的执行时长计时。
当终端设备检测到任一待处理的消息的执行时长大于或等于预设执行阈值时,如果仍未检测到该待处理的消息的执行完成信息,则表示该待处理的消息的执行时长过长,在主线程引起了消息阻塞故障。此时,终端设备可以查询与主线程连接的输入事件管道中是否存在用户输入事件以及消息队列中是否存在vsync信号。
如果终端设备检测到与主线程连接的输入事件管道中存在用户输入事件或消息队列中存在vsync信号,则判定发生冻屏故障,终端设备抓取主线程的堆栈信息,将抓取到的堆栈信息记录为第二冻屏故障日志。
如果终端设备检测到与主线程连接的输入事件管道中不存在用户输入事件且消息队列中不存在vsync信号,则判定未发生冻屏故障。
在上述描述的冻屏检测方法中,将待处理消息的处理时长划分为驻留时长和执行时长,并分别对驻留时长和执行时长进行监测,可以有效辨别主线程的消息阻塞故障的起因,记录相应的第一冻屏故障日志或第二冻屏故障日志,从而使开发人员可以根据第一冻屏故障日志或第二冻屏故障日志进行针对性地优化调整。
此外,在发生冻屏故障时,终端设备需要抓取主线程的堆栈信息生成冻屏故障日志。在一种可能的实现方式中,终端设备可以先根据预设执行阈值、用户输入事件以及vsync信号确定是否发生冻屏故障,确定发生了冻屏故障之后再执行抓取堆栈信息的动作。
当终端设备采取上述方案抓取主线程的堆栈信息时,终端设备抓取的堆栈信息不一定发生冻屏故障时主线程的堆栈信息。
例如,如图3所示,假设预设执行阈值被设置为2s。终端设备检测到消息A在T1时刻离开主线程的消息队列开始被处理,开始对消息A的执行时长进行计时。在T2时刻时,消息A的执行时长等于2s,并且与该主线程连接的输入事件管道中存在用户输入事件,则终端设备判定该应用程序发生了冻屏故障。然后,终端设备在T4时刻抓取该主线程的堆栈信息。但是,在终端设备抓取主线程的堆栈信息之前,消息A在T3时刻被处理完毕,主线程开始处理下一个待处理的消息B,导致终端设备在T4时刻抓取主线程的堆栈信息时,抓取到的堆栈信息是主线程处理消息B的堆栈信息,而不是主线程处理消息A的堆栈信息。此时,终端设备抓取的堆栈信息并非发生冻屏故障时的堆栈信息,终端设备记录的冻屏故障日志无法协助开发人员定位冻屏故障的起因。
因此,在另一种可能的实现方案中,终端设备可以设置两个预设执行阈值,分别为第一预设执行阈值和第二预设执行阈值。其中,第一预设执行阈值和第二预设执行阈值的具体数值可以根据实际情况进行设置,且,第一预设执行阈值的数值小于第二预设执行阈值。例如,终端设备可以将第一预设执行阈值设置为1s,将第二预设执行阈值设置为2s。
终端设备对待处理的消息的执行时长开始计时之后,对待处理消息的执行时长进行监测。
当待处理的消息的执行时长大于或等于第一预设执行阈值时,如果终端设备尚未获取到该待处理的消息的执行完成信号,则表示该待处理的消息的执行时长较长,可能会导致冻屏故障,终端设备可以抓取主线程的堆栈信息,存储抓取到的堆栈信息。
当待处理的消息的执行时长大于或等于第二预设执行阈值时,如果终端设备尚未获取到该待处理的消息的执行完成信息,则终端设备可以检测与上述主线程连接的输入事件管道中是否存在用户输入事件以及消息队列中是否存在vsync信号。
如果上述输入事件管道中不存在用户输入事件且消息队列中不存在vsync信号,则终端设备判定该应用程序未发生冻屏故障。
如果上述输入事件管道中存在用户输入事件或消息队列中存在vsync信号,则表示该待处理的消息的执行时长过长,造成了用户可感知的主线程的消息阻塞故障,终端设备判定该应用程序发生了冻屏故障,将上述预先存储的抓取到的堆栈信息记录为第二冻屏故障日志。
由于上述抓取到的堆栈信息是终端设备在上述待处理的消息被处理的过程中抓取的,所以可以确保上述抓取到的堆栈信息是冻屏故障现场的堆栈信息。
例如,如图4所示,假设第一预设执行阈值被设置为1s,第二预设执行阈值被设置为2s。终端设备检测到消息A在T1时刻离开主线程的消息队列开始被处理,开始对消息A的执行时长进行计时。在T5时刻,消息A的执行时长等于1s,终端设备抓取主线程的堆栈信息,保存堆栈信息,并继续对消息A的执行时长进行监测。在T2时刻,消息A的执行时长等于2s,终端设备监测到消息A尚未处理完成,则对与该主线程连接的输入事件管道以及消息队列进行检测。终端设备发现上述输入事件管道中存在用户输入事件,则终端设备判定该应用程序发生了冻屏故障。终端设备在T4时刻,将在T5时刻抓取到的堆栈信息记录为第二冻屏故障日志。此时,由于上述堆栈信息是在T5时刻抓取的,在T5时刻消息A尚未处理完成,因此,即使消息A在T3时刻处理完成,主线程开始处理待处理的消息B,终端设备也能确保抓取的堆栈信息是发生冻屏故障时的堆栈信息,确保第二冻屏故障日志的准确性,从而有效协助开发人员定位冻屏故障的起因。
其次,如果终端设备在接收到待处理的消息的执行完成信号时,该待处理的消息的执行时长大于或等于第一预设执行阈值,且小于第二预设执行阈值,则表示该待处理的消息在处理的过程中虽然占用了较多的时间,但是尚未引起主线程的消息堵塞故障。此时,终端设备可以将上述预先存储的抓取到的堆栈信息记录为卡顿故障日志,以便开发人员根据卡顿故障日志对应用程序进行优化调整。
终端设备在确定应用程序发生冻屏故障之后,如果开发人员预设设置了应用恢复操作,则终端设备可以对上述主线程对应的应用程序执行预设应用恢复操作,从而使应用程序尽快恢复到正常工作状态,提高用户的使用体验。
上述应用恢复操作的具体内容可以根据实际情况进行设置。例如,上述应用恢复操作可以为重启该应用程序。
为了更好地对本申请实施例提供的冻屏检测方法进行说明,以下结合具体的场景进行描述。
如图5和图6所示,当用户启动终端设备上的某一个应用程序时,终端设备创建该应用程序对应的主线程502,主线程502中包括消息队列5021和处理模块5022。终端设备的输入子系501统创建与主线程502连接的输入事件管道503,并且,终端设备启用与主线程502相互独立的线程504,通过线程504监测主线程502内各个待处理的消息的处理时长、检测输入事件管道503中是否存在用户输入事件以及检查消息队列5021中是否存在vsync信号。
场景一:假设终端设备内设置的预设时长阈值为5s。
当待处理的消息A进入消息队列5021时,主线程502发送第一信号给线程504,线程504根据第一信号开始对消息A的处理时长进行计时。
当消息A的处理时长大于或等于5s时,线程504尚未接收到主线程502发送的与消息A对应的执行完成信号,表示消息A的处理时长超时。
此时,线程504查询输入事件管道503中是否存在用户输入事件以及查询消息队列5021中是否存在vsync信号。线程504查询到输入事件管道503中存在用户输入事件,则判定发生冻屏故障,抓取主线程502的堆栈信息,将抓取到的堆栈信息记录为冻屏故障日志。
场景二:假设终端设备内设置的预设驻留阈值为2s。
当待处理的消息B进入消息队列时,主线程502发送第一信号给线程504,线程504根据第一信号获取到消息B进入消息队列的第一时间。当消息B离开消息队列时,主线程502发送第二信号给线程504,线程504根据第二信号获取到消息B离开消息队列的第二时间。
线程504将第二时间减去第一时间,得到消息B的驻留时长为3s。此时,线程504查询输入事件管道503中是否存在用户输入事件以及查询消息队列5021中是否存在vsync信号。线程504查询到输入事件管道503中存在用户输入事件,则判定发生冻屏故障,抓取主线程502的堆栈信息,将抓取到的堆栈信息记录为第一冻屏故障日志。
场景三:假设终端设备内设置的预设驻留阈值为2s,预设执行阈值为3s。
当待处理的消息C进入消息队列时,主线程502发送第一信号给线程504,线程504根据第一信号获取到消息C进入消息队列的第一时间。当消息C离开消息队列时,主线程502发送第二信号给线程504,线程504根据第二信号获取到消息C离开消息队列的第二时间。
线程504将第二时间减去第一时间,得到消息C的驻留时长为1s,消息C的驻留时长小于预设驻留阈值。此时,线程504开始对消息C的执行时长进行计时。
当消息C的执行时长大于或等于3s时,线程504尚未接收到主线程502发送的与消息C对应的执行完成信号,表示消息C的执行时长超时。
此时,线程504查询输入事件管道503中是否存在用户输入事件以及查询消息队列5021中是否存在vsync信号。线程504查询到输入事件管道503中存在用户输入事件,则判定发生冻屏故障,抓取主线程502的堆栈信息,将抓取到的堆栈信息记录为第二冻屏故障日志。
场景四:假设终端设备内设置的预设驻留阈值为2s,第一预设执行阈值为2s,第二预设执行阈值为3s。
当待处理的消息D进入消息队列时,主线程502发送第一信号给线程504,线程504根据第一信号获取到消息D进入消息队列的第一时间。当消息D离开消息队列时,主线程502发送第二信号给线程504,线程504根据第二信号获取到消息D离开消息队列的第二时间。
线程504将第二时间减去第一时间,得到消息D的驻留时长为1s,消息D的驻留时长小于预设驻留阈值。此时,线程504开始对消息D的执行时长进行计时。
当消息D的执行时长大于或等于2s时,线程504尚未接收到主线程502发送的与消息D对应的执行完成信号,则线程504抓取主线程502的堆栈信息,存储抓取到的堆栈信息。
当消息D的执行时长为2.3s时,线程504接收到主线程502发送的与消息D对应的执行完成信号,则线程504停止对消息D的执行时长的计时,将上述存储的抓取到的堆栈信息记录为卡顿故障日志。
场景五:假设终端设备内设置的预设驻留阈值为2s,第一预设执行阈值为2s,第二预设执行阈值为3s。
当待处理的消息E进入消息队列时,主线程502发送第一信号给线程504,线程504根据第一信号获取到消息E进入消息队列的第一时间。当消息E离开消息队列时,主线程502发送第二信号给线程504,线程504根据第二信号获取到消息E离开消息队列的第二时间。
线程504将第二时间减去第一时间,得到消息E的驻留时长为1s,消息E的驻留时长小于预设驻留阈值。此时,线程504开始对消息E的执行时长进行计时。
当消息E的执行时长大于或等于2s时,线程504尚未接收到主线程502发送的与消息E对应的执行完成信号,则线程504抓取主线程502的堆栈信息,存储抓取到的堆栈信息。
当消息E的执行时长大于或等于2s时,线程504尚未接收到主线程502发送的与消息E对应的执行完成信号,则线程504查询输入事件管道503中是否存在用户输入事件以及查询消息队列5021中是否存在vsync信号。线程504查询到输入事件管道503中存在用户输入事件,则判定发生冻屏故障,将上述存储的抓取到的堆栈信息记录为第二冻屏故障日志。
应理解,上述实施例中各步骤的序号的大小并不意味着执行顺序的先后,各过程的执行顺序应以其功能和内在逻辑确定,而不应对本申请实施例的实施过程构成任何限定。
请参阅图7,本申请实施例提供了一种冻屏检测装置,为便于说明,仅示出与本申请相关的部分,如图7所示,冻屏检测装置包括,
时长监测模块701,用于监测主线程中待处理的消息的处理时长;
冻屏检测模块702,用于若所述待处理的消息的处理时长大于或等于预设时长阈值,且与所述主线程连接的输入事件管道中存在用户输入事件或所述主线程的消息队列中存在垂直同步信号,则判定发生冻屏故障,记录冻屏故障日志。
进一步地,所述处理时长包括驻留时长;
所述时长监测模块701包括:
时间获取子模块,用于获取所述待处理的消息进入所述主线程的消息队列的第一时间以及所述待处理的消息离开所述消息队列的第二时间;
驻留时长子模块,用于根据所述第一时间和所述第二时间计算所述待处理的消息的驻留时长;
所述冻屏检测模块702包括:
第一冻屏子模块,用于若所述待处理的消息的驻留时长大于或等于预设驻留阈值,且与所述主线程连接的输入事件管道中存在用户输入事件或所述主线程的消息队列中存在垂直同步信号,则判定发生冻屏故障,抓取所述主线程的堆栈信息,并将抓取到的堆栈信息记录为第一冻屏故障日志。
进一步地,所述处理时长包括执行时长;
所述时长监测模块701包括:
执行计时子模块,用于当所述待处理的消息离开所述消息队列时,对所述待处理的消息的执行时长进行计时;
所述冻屏检测模块702包括:
第二冻屏子模块,用于当所述待处理的消息的执行时长大于或等于预设执行阈值时,若未检测到所述待处理的消息的执行完成信号且与所述主线程连接的输入事件管道中存在用户输入事件或所述主线程的消息队列中存在垂直同步信号,则判定发生冻屏故障,抓取所述主线程的堆栈信息,并将抓取到的堆栈信息记录为第二冻屏故障日志。
进一步地,所述第二冻屏子模块包括:
信息抓取子模块,用于当所述待处理的消息的执行时长大于或等于第一预设执行阈值时,若未检测到所述待处理的消息的执行完成信号,则抓取所述主线程的堆栈信息,存储抓取到的堆栈信息;
冻屏判定子模块,用于当所述待处理的消息的执行时长大于或等于第二预设执行阈值时,若未检测到所述待处理的消息的执行完成信号且与所述主线程连接的输入事件管道中存在用户输入事件或所述主线程的消息队列中存在垂直同步信号,则判定发生冻屏故障,将所述抓取到的堆栈信息记录为第二冻屏故障日志,其中,所述第一预设执行阈值小于所述第二预设执行阈值。
进一步地,所述第二冻屏子模块还包括:
卡顿判定子模块,用于若接收到所述待处理的消息的执行完成信号时,所述待处理的消息的执行时长大于或等于所述第一预设执行阈值,且小于所述第二预设执行阈值,则将所述抓取到的堆栈信息记录为卡顿故障日志。
进一步地,所述时长监测模块701,具体用于通过与所述主线程独立的第一线程监测主线程中待处理的消息的处理时长。
进一步地,所述装置还包括:
应用恢复模块,用于对所述主线程对应的应用程序执行预设应用恢复操作。
进一步地,所述用户输入事件包括用户操作事件和/或垂直同步信号。
需要说明的是,上述装置/单元之间的信息交互、执行过程等内容,由于与本申请方法实施例基于同一构思,其具体功能及带来的技术效果,具体可参见方法实施例部分,此处不再赘述。
请参阅图8,本申请实施例还提供了一种电子设备。如图8所示,该实施例的电子设备80包括:处理器80、存储器81、存储在所述存储器81中并可在所述处理器80上运行的计算机程序82。所述处理器80执行所述计算机程序82时实现上述冻屏检测方法实施例中的步骤,例如图2所示的步骤S201至S202。或者,所述处理器80执行所述计算机程序82时实现上述各装置实施例中各模块/单元的功能,例如图7所示模块701至702的功能。
示例性的,所述计算机程序82可以被分割成一个或多个模块/单元,所述一个或者多个模块/单元被存储在所述存储器81中,并由所述处理器80执行,以完成本申请。所述一个或多个模块/单元可以是能够完成特定功能的一系列计算机程序指令段,该指令段用于描述所述计算机程序82在所述终端设备8中的执行过程。例如,所述计算机程序82可以被分割成时长监测模块以及冻屏检测模块,各模块具体功能如下:
时长监测模块,用于监测主线程中待处理的消息的处理时长;
冻屏检测模块,用于若所述待处理的消息的处理时长大于或等于预设时长阈值,且与所述主线程连接的输入事件管道中存在用户输入事件或所述主线程的消息队列中存在垂直同步信号,则判定发生冻屏故障,记录冻屏故障日志。
所述终端设备8可以是桌上型计算机、笔记本、掌上电脑及云端服务器等计算设备。所述终端设备可包括,但不仅限于,处理器80、存储器81。本领域技术人员可以理解,图8仅仅是终端设备8的示例,并不构成对终端设备8的限定,可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件,例如所述终端设备还可以包括输入输出设备、网络接入设备、总线等。
所称处理器80可以是中央处理单元(Central Processing Unit,CPU),还可以是其他通用处理器、数字信号处理器(Digital Signal Processor,DSP)、专用集成电路(Application Specific Integrated Circuit,ASIC)、现场可编程门阵列(Field-Programmable Gate Array,FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件等。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。
所述存储器81可以是所述终端设备8的内部存储单元,例如终端设备8的硬盘或内存。所述存储器81也可以是所述终端设备8的外部存储设备,例如所述终端设备8上配备的插接式硬盘,智能存储卡(Smart Media Card,SMC),安全数字(Secure Digital,SD)卡,闪存卡(Flash Card)等。进一步地,所述存储器81还可以既包括所述终端设备8的内部存储单元也包括外部存储设备。所述存储器81用于存储所述计算机程序以及所述终端设备所需的其他程序和数据。所述存储器81还可以用于暂时地存储已经输出或者将要输出的数据。
所属领域的技术人员可以清楚地了解到,为了描述的方便和简洁,仅以上述各功能单元、模块的划分进行举例说明,实际应用中,可以根据需要而将上述功能分配由不同的功能单元、模块完成,即将所述装置的内部结构划分成不同的功能单元或模块,以完成以上描述的全部或者部分功能。实施例中的各功能单元、模块可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中,上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。另外,各功能单元、模块的具体名称也只是为了便于相互区分,并不用于限制本申请的保护范围。上述***中单元、模块的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。
在上述实施例中,对各个实施例的描述都各有侧重,某个实施例中没有详述或记载的部分,可以参见其它实施例的相关描述。
本领域普通技术人员可以意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、或者计算机软件和电子硬件的结合来实现。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本申请的范围。
在本申请所提供的实施例中,应该理解到,所揭露的装置/终端设备和方法,可以通过其它的方式实现。例如,以上所描述的装置/终端设备实施例仅仅是示意性的,例如,所述模块或单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个***,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通讯连接可以是通过一些接口,装置或单元的间接耦合或通讯连接,可以是电性,机械或其它的形式。
所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
另外,在本申请各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。
所述集成的模块/单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本申请实现上述实施例方法中的全部或部分流程,也可以通过计算机程序来指令相关的硬件来完成,所述的计算机程序可存储于一计算机可读存储介质中,该计算机程序在被处理器执行时,可实现上述各个方法实施例的步骤。其中,所述计算机程序包括计算机程序代码,所述计算机程序代码可以为源代码形式、对象代码形式、可执行文件或某些中间形式等。所述计算机可读介质可以包括:能够携带所述计算机程序代码的任何实体或装置、记录介质、U盘、移动硬盘、磁碟、光盘、计算机存储器、只读存储器(ROM,Read-Only Memory)、随机存取存储器(RAM,Random Access Memory)、电载波信号、电信信号以及软件分发介质等。需要说明的是,所述计算机可读介质包含的内容可以根据司法管辖区内立法和专利实践的要求进行适当的增减,例如在某些司法管辖区,根据立法和专利实践,计算机可读介质不包括电载波信号和电信信号。
以上所述实施例仅用以说明本申请的技术方案,而非对其限制;尽管参照前述实施例对本申请进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本申请各实施例技术方案的精神和范围,均应包含在本申请的保护范围之内。
Claims (12)
1.一种冻屏检测方法,其特征在于,包括:
监测主线程中待处理的消息的处理时长;所述处理时长包括执行时长;所述监测主线程中待处理的消息的处理时长,包括:当所述待处理的消息离开消息队列时,对所述待处理的消息的执行时长进行计时;
若所述待处理的消息的处理时长大于或等于预设时长阈值,且与所述主线程连接的输入事件管道中存在用户输入事件或所述主线程的消息队列中存在垂直同步信号,则判定发生冻屏故障,记录冻屏故障日志,包括:当所述待处理的消息的执行时长大于或等于预设执行阈值时,若未检测到所述待处理的消息的执行完成信号且与所述主线程连接的输入事件管道中存在用户输入事件或所述主线程的消息队列中存在垂直同步信号,则判定发生冻屏故障,抓取所述主线程的堆栈信息,并将抓取到的堆栈信息记录为第二冻屏故障日志;其中,用户输入事件是用户对终端设备进行操作而触发的事件;
所述当所述待处理的消息的执行时长大于或等于预设执行阈值时,若未检测到所述待处理的消息的执行完成信号且与所述主线程连接的输入事件管道中存在用户输入事件或所述主线程的消息队列中存在垂直同步信号,则判定发生冻屏故障,抓取所述主线程的堆栈信息,并将抓取到信息记录为第二冻屏故障日志包括:
当所述待处理的消息的执行时长大于或等于第一预设执行阈值时,若未检测到所述待处理的消息的执行完成信号,则抓取所述主线程的堆栈信息,存储抓取到的堆栈信息;
当所述待处理的消息的执行时长大于或等于第二预设执行阈值时,若未检测到所述待处理的消息的执行完成信号且与所述主线程连接的输入事件管道中存在用户输入事件或所述主线程的消息队列中存在垂直同步信号,则判定发生冻屏故障,将所述抓取到的堆栈信息记录为第二冻屏故障日志,其中,所述第一预设执行阈值小于所述第二预设执行阈值。
2.如权利要求1所述的冻屏检测方法,其特征在于,所述处理时长包括驻留时长;
所述监测主线程中待处理的消息的处理时长包括:
获取所述待处理的消息进入所述主线程的消息队列的第一时间以及所述待处理的消息离开所述消息队列的第二时间;
根据所述第一时间和所述第二时间计算所述待处理的消息的驻留时长;
所述若所述待处理的消息的处理时长大于或等于预设时长阈值,且与所述主线程连接的输入事件管道中存在用户输入事件或所述主线程的消息队列中存在垂直同步信号,则判定发生冻屏故障,记录冻屏故障日志包括:
若所述待处理的消息的驻留时长大于或等于预设驻留阈值,且与所述主线程连接的输入事件管道中存在用户输入事件或所述主线程的消息队列中存在垂直同步信号,则判定发生冻屏故障,抓取所述主线程的堆栈信息,并将抓取到的堆栈信息记录为第一冻屏故障日志。
3.如权利要求1所述的冻屏检测方法,其特征在于,所述方法还包括:
若接收到所述待处理的消息的执行完成信号时,所述待处理的消息的执行时长大于或等于所述第一预设执行阈值,且小于所述第二预设执行阈值,则将所述抓取到的堆栈信息记录为卡顿故障日志。
4.如权利要求1所述的冻屏检测方法,其特征在于,所述监测主线程中待处理的消息的处理时长包括:
通过与所述主线程独立的第一线程监测主线程中待处理的消息的处理时长。
5.如权利要求1所述的冻屏检测方法,其特征在于,在所述判定发生冻屏故障之后,还包括:
对所述主线程对应的应用程序执行预设应用恢复操作。
6.一种冻屏检测装置,其特征在于,包括:
时长监测模块,用于监测主线程中待处理的消息的处理时长;所述处理时长包括执行时长;所述时长监测模块包括:执行计时子模块,用于当所述待处理的消息离开消息队列时,对所述待处理的消息的执行时长进行计时;
冻屏检测模块,用于若所述待处理的消息的处理时长大于或等于预设时长阈值,且与所述主线程连接的输入事件管道中存在用户输入事件或所述主线程的消息队列中存在垂直同步信号,则判定发生冻屏故障,记录冻屏故障日志;
所述冻屏检测模块包括:
第二冻屏子模块,用于当所述待处理的消息的执行时长大于或等于预设执行阈值时,若未检测到所述待处理的消息的执行完成信号且与所述主线程连接的输入事件管道中存在用户输入事件或所述主线程的消息队列中存在垂直同步信号,则判定发生冻屏故障,抓取所述主线程的堆栈信息,并将抓取到的堆栈信息记录为第二冻屏故障日志;其中,用户输入事件是用户对终端设备进行操作而触发的事件;
所述第二冻屏子模块包括:
信息抓取子模块,用于当所述待处理的消息的执行时长大于或等于第一预设执行阈值时,若未检测到所述待处理的消息的执行完成信号,则抓取所述主线程的堆栈信息,存储抓取到的堆栈信息;
冻屏判定子模块,用于当所述待处理的消息的执行时长大于或等于第二预设执行阈值时,若未检测到所述待处理的消息的执行完成信号且与所述主线程连接的输入事件管道中存在用户输入事件或所述主线程的消息队列中存在垂直同步信号,则判定发生冻屏故障,将所述抓取到的堆栈信息记录为第二冻屏故障日志,其中,所述第一预设执行阈值小于所述第二预设执行阈值。
7.如权利要求6所述的冻屏检测装置,其特征在于,所述处理时长包括驻留时长;
所述时长监测模块包括:
时间获取子模块,用于获取所述待处理的消息进入所述主线程的消息队列的第一时间以及所述待处理的消息离开所述消息队列的第二时间;
驻留时长子模块,用于根据所述第一时间和所述第二时间计算所述待处理的消息的驻留时长;
所述冻屏检测模块包括:
第一冻屏子模块,用于若所述待处理的消息的驻留时长大于或等于预设驻留阈值,且与所述主线程连接的输入事件管道中存在用户输入事件或所述主线程的消息队列中存在垂直同步信号,则判定发生冻屏故障,抓取所述主线程的堆栈信息,并将抓取到的堆栈信息记录为第一冻屏故障日志。
8.如权利要求6所述的冻屏检测装置,其特征在于,所述第二冻屏子模块还包括:
卡顿判定子模块,用于若接收到所述待处理的消息的执行完成信号时,所述待处理的消息的执行时长大于或等于所述第一预设执行阈值,且小于所述第二预设执行阈值,则将所述抓取到的堆栈信息记录为卡顿故障日志。
9.如权利要求6所述的冻屏检测装置,其特征在于,所述时长监测模块,具体用于通过与所述主线程独立的第一线程监测主线程中待处理的消息的处理时长。
10.如权利要求6所述的冻屏检测装置,其特征在于,所述装置还包括:
应用恢复模块,用于对所述主线程对应的应用程序执行预设应用恢复操作。
11.一种终端设备,包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,其特征在于,所述处理器执行所述计算机程序时实现如权利要求1至5任一项所述方法的步骤。
12.一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现如权利要求1至5任一项所述方法的步骤。
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010354202.1A CN113568801B (zh) | 2020-04-29 | 2020-04-29 | 冻屏检测方法、装置、终端设备及计算机存储介质 |
PCT/CN2021/084388 WO2021218548A1 (zh) | 2020-04-29 | 2021-03-31 | 冻屏检测方法、装置、终端设备及计算机存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010354202.1A CN113568801B (zh) | 2020-04-29 | 2020-04-29 | 冻屏检测方法、装置、终端设备及计算机存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN113568801A CN113568801A (zh) | 2021-10-29 |
CN113568801B true CN113568801B (zh) | 2023-11-03 |
Family
ID=78158461
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202010354202.1A Active CN113568801B (zh) | 2020-04-29 | 2020-04-29 | 冻屏检测方法、装置、终端设备及计算机存储介质 |
Country Status (2)
Country | Link |
---|---|
CN (1) | CN113568801B (zh) |
WO (1) | WO2021218548A1 (zh) |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107590057A (zh) * | 2017-09-28 | 2018-01-16 | 努比亚技术有限公司 | 冻屏监测与解决方法、移动终端及计算机可读存储介质 |
CN108228358A (zh) * | 2017-12-06 | 2018-06-29 | 广东欧珀移动通信有限公司 | 修正垂直同步信号的方法、装置、移动终端以及存储介质 |
CN108345524A (zh) * | 2017-01-22 | 2018-07-31 | 腾讯科技(深圳)有限公司 | 应用程序监控方法及应用程序监控装置 |
CN108519923A (zh) * | 2018-03-01 | 2018-09-11 | 北京三快在线科技有限公司 | 一种卡顿检测方法及装置和电子设备 |
Family Cites Families (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8990671B2 (en) * | 2011-10-31 | 2015-03-24 | Buckyball Mobile Inc. | Method and system of jamming specified media content by age category |
US20150121178A1 (en) * | 2011-10-31 | 2015-04-30 | Amit V. KARMARKAR | Audio content editor for jamming restricted content |
CN107704133B (zh) * | 2017-09-28 | 2021-09-21 | 努比亚技术有限公司 | 冻屏监测与解决方法、移动终端及计算机可读存储介质 |
-
2020
- 2020-04-29 CN CN202010354202.1A patent/CN113568801B/zh active Active
-
2021
- 2021-03-31 WO PCT/CN2021/084388 patent/WO2021218548A1/zh active Application Filing
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108345524A (zh) * | 2017-01-22 | 2018-07-31 | 腾讯科技(深圳)有限公司 | 应用程序监控方法及应用程序监控装置 |
CN107590057A (zh) * | 2017-09-28 | 2018-01-16 | 努比亚技术有限公司 | 冻屏监测与解决方法、移动终端及计算机可读存储介质 |
CN108228358A (zh) * | 2017-12-06 | 2018-06-29 | 广东欧珀移动通信有限公司 | 修正垂直同步信号的方法、装置、移动终端以及存储介质 |
CN108519923A (zh) * | 2018-03-01 | 2018-09-11 | 北京三快在线科技有限公司 | 一种卡顿检测方法及装置和电子设备 |
Also Published As
Publication number | Publication date |
---|---|
CN113568801A (zh) | 2021-10-29 |
WO2021218548A1 (zh) | 2021-11-04 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN101345663B (zh) | 心跳检测方法和心跳检测设备 | |
WO2022037251A1 (zh) | 视频数据处理方法及装置 | |
US10601930B2 (en) | Lease-based heartbeat protocol method and apparatus | |
CN110188016B (zh) | 应用程序无响应阻塞的检测方法、终端以及存储介质 | |
CN110708696B (zh) | 网络数据的恢复方法、装置、存储介质及电子设备 | |
CN111818632B (zh) | 一种设备同步的方法、装置、设备及存储介质 | |
CN101316203B (zh) | 嵌入式ip终端网络连接状态监测方法 | |
CN111949511A (zh) | 应用程序的卡顿处理方法、装置、终端及存储介质 | |
CN113568801B (zh) | 冻屏检测方法、装置、终端设备及计算机存储介质 | |
CN112965799B (zh) | 任务状态的提示方法、装置、电子设备和介质 | |
WO2023216839A1 (zh) | 一种冻屏检测方法、装置、电子设备及车辆 | |
CN112887717A (zh) | 智慧终端视频编码优化方法和装置、设备及存储介质 | |
CN115865734B (zh) | 一种故障检测方法、数据生成方法、装置、设备及介质 | |
CN113127113A (zh) | 一种操作指令的响应方法和计算机设备 | |
CN114554110B (zh) | 视频生成方法、装置、电子设备和存储介质 | |
CN113205079B (zh) | 一种人脸检测方法、装置、电子设备及存储介质 | |
CN115878379A (zh) | 一种数据备份方法、主服务器、备份服务器及存储介质 | |
CN114281583A (zh) | 设备检测方法、装置、电子设备及可读存储介质 | |
CN114024878A (zh) | 数据传输方法、装置、介质和设备 | |
CN109167808B (zh) | 一种数据处理方法、装置和*** | |
CN111510772A (zh) | 一种平衡视频帧率误差的方法、装置、设备及存储介质 | |
CN111935313B (zh) | 一种连接池管理方法及装置 | |
CN114679443A (zh) | 一种下载视频数据的方法、装置、电子设备及存储介质 | |
CN111935309B (zh) | 一种循环任务管理方法及装置 | |
CN114826886B (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 | ||
GR01 | Patent grant | ||
GR01 | Patent grant |