CN107818036B - 黑屏检测方法、移动终端及计算机可读存储介质 - Google Patents

黑屏检测方法、移动终端及计算机可读存储介质 Download PDF

Info

Publication number
CN107818036B
CN107818036B CN201711055461.9A CN201711055461A CN107818036B CN 107818036 B CN107818036 B CN 107818036B CN 201711055461 A CN201711055461 A CN 201711055461A CN 107818036 B CN107818036 B CN 107818036B
Authority
CN
China
Prior art keywords
thread
monitoring data
preset
mobile terminal
black screen
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
Application number
CN201711055461.9A
Other languages
English (en)
Other versions
CN107818036A (zh
Inventor
安邦军
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Nubia Technology Co Ltd
Original Assignee
Nubia Technology Co Ltd
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Nubia Technology Co Ltd filed Critical Nubia Technology Co Ltd
Priority to CN201711055461.9A priority Critical patent/CN107818036B/zh
Publication of CN107818036A publication Critical patent/CN107818036A/zh
Application granted granted Critical
Publication of CN107818036B publication Critical patent/CN107818036B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/3055Monitoring arrangements for monitoring the status of the computing system or of the computing system component, e.g. monitoring if the computing system is on, off, available, not available
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/3051Monitoring 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
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/34Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
    • G06F11/3466Performance evaluation by tracing or monitoring
    • G06F11/3476Data logging
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M1/00Substation equipment, e.g. for use by subscribers
    • H04M1/24Arrangements for testing

Abstract

本发明公开了一种黑屏检测方法、移动终端及计算机可读存储介质,所述黑屏检测方法包括以下步骤:对所述移动终端的显示服务线程中的预设关键流程进行监测,以获取关键流程监测数据,并对第一预设进程进行监测,以获取进程监测数据;对与所述显示服务线程进行交互的属于第二预设进程的预设线程进行监测,以获取线程监测数据;根据所述关键流程监测数据、所述进程监测数据和所述线程监测数据判断所述移动终端是否出现黑屏故障;在所述移动终端出现黑屏故障时,从所述关键流程监测数据、所述进程监测数据和所述线程监测数据中提取黑屏故障信息,并将所述黑屏故障信息输出至特征日志文件。本发明能够极大的降低人力成本和时间成本。

Description

黑屏检测方法、移动终端及计算机可读存储介质
技术领域
本发明涉及移动终端技术领域,尤其涉及一种黑屏检测方法、移动终端及计算机可读存储介质。
背景技术
随着移动终端技术的发展,移动终端中集成的APP(Application,应用程序)也越来越多,目前基于移动终端的不同场景的应用程序数以万计,随着用户在移动终端上安装的第三方应用和服务软件数量越来越多,人们日常使用移动终端时,移动终端容易出现黑屏现象。
目前,当移动终端出现黑屏现象时,需要用户手动强制重启移动终端使其恢复正常,用户体验不好,此外,导致移动终端出现黑屏现象的原因多种多样,通过重启移动终端并不一定能使其恢复正常,需要将移动终端退回厂家维修,需要开发人员耗费较多的时间对移动终端进行检测定位黑屏原因。因此,如何是目前亟待解决的问题。
上述内容仅用于辅助理解本发明的技术方案,并不代表承认上述内容是现有技术。
发明内容
本发明的主要目的在于提供一种黑屏检测方法、移动终端及计算机可读存储介质,旨在解决如何如何快速定位黑屏原因,降低人力成本和时间成本的技术问题。
为实现上述目的,本发明提供一种黑屏检测方法,所述黑屏检测方法应用于移动终端,所述黑屏检测方法包括以下步骤:
对所述移动终端的显示服务线程中的预设关键流程进行监测,以获取关键流程监测数据,并对第一预设进程进行监测,以获取进程监测数据;
对与所述显示服务线程进行交互的属于第二预设进程的预设线程进行监测,以获取线程监测数据;
根据所述关键流程监测数据、所述进程监测数据和所述线程监测数据判断所述移动终端是否出现黑屏故障;
在所述移动终端出现黑屏故障时,从所述关键流程监测数据、所述进程监测数据和所述线程监测数据中提取黑屏故障信息,并将所述黑屏故障信息输出至特征日志文件。
可选地,所述根据所述关键流程监测数据、所述进程监测数据和所述线程监测数据判断所述移动终端是否出现黑屏故障的步骤包括:
根据所述关键流程监测数据判断所述移动终端的显示服务线程中的预设关键流程是否处于异常状态;
在所述移动终端的显示服务线程中的预设关键流程未处于异常状态时,根据所述进程监测数据判断所述第一预设进程是否处于阻塞状态;
在所述第一预设进程处于阻塞状态时,根据所述线程监测数据判断所述预设线程是否处于阻塞状态;
在所述预设线程处于阻塞状态时,判定所述移动终端出现黑屏故障,并在所述预设线程未处于阻塞状态时,判定所述移动终端未出现黑屏故障。
可选地,所述根据所述线程监测数据判断所述预设线程是否处于异常状态的步骤包括:
从所述线程监测数据中读取所述预设线程的线程状态值,并判断所述线程状态值是否处于预设线程状态值集合;
在所述线程状态值处于预设线程状态值集合时,判定所述预设线程处于阻塞状态,并在所述线程状态值未处于预设线程状态值集合时,判定所述预设线程未处于阻塞状态。
可选地,所述对与所述显示服务线程进行交互的属于第二预设进程的预设线程进行监测,以获取线程监测数据的步骤之后,所述黑屏检测方法还包括:
将所述线程监测数据写入监测数据库,并以间隔预设时间从所述监测数据库中读取线程监测数据;
根据所述线程监测数据中的所述预设线程的线程状态值判断所述线程监测数据是否为冗余数据;
在所述线程监测数据为冗余数据时,从所述监测数据库中删除所述线程监测数据。
可选地,所述根据所述关键流程监测数据、所述进程监测数据和所述线程监测数据判断所述移动终端是否出现黑屏故障的步骤之后,所述黑屏检测方法还包括:
在所述移动终端出现黑屏故障时,将所述关键流程监测数据、所述进程监测数据和所述线程监测数据存储至预设存储分区;
在检测到所述移动终端处于熄屏待机状态时,对所述预设存储分区中的关键流程监测数据、进程监测数据和线程监测数据进行去冗余处理。
可选地,所述对所述预设存储分区中的关键流程监测数据、进程监测数据和线程监测数据进行去冗余处理的步骤之后,所述黑屏检测方法还包括:
判断所述预设存储分区中所述关键流程监测数据、所述进程监测数据和所述线程监测数据的存储数据量是否超过预设阈值;
在所述存储数据量超过预设阈值时,从所述预设存储分区中选取待删除数据,并对所述待删除数据进行删除操作。
此外,为实现上述目的,本发明还提供一种移动终端,所述移动终端包括:存储器、处理器及存储在所述存储器上并可在所述处理器上运行的黑屏检测程序,所述黑屏检测程序被所述处理器执行时实现如上所述的黑屏检测方法的步骤。
本发明还提供一种计算机可读存储介质,其特征在于,所述计算机可读存储介质上存储有黑屏检测程序,所述黑屏检测程序被处理器执行时实现如上所述的黑屏检测方法的步骤。
本发明提供一种黑屏检测方法、移动终端及计算机可读存储介质,对移动终端的显示服务线程中的预设关键流程进行监测,以获取关键流程监测数据,并对第一预设进程进行监测,以获取进程监测数据,然后对与该显示服务线程进行交互的属于第二预设进程的预设线程进行监测,以获取线程监测数据,并根据该关键流程监测数据、该进程监测数据和该线程监测数据判断该移动终端是否出现黑屏故障,最后在该移动终端出现黑屏故障时,从该关键流程监测数据、该进程监测数据和该线程监测数据中提取黑屏故障信息,并将该黑屏故障信息输出至特征日志文件,本方案通过对移动终端的显示服务线程中的关键流程进行监测、对预设进程进行监测、以及对与该显示服务线程进行交互的预设线程进行监测,并在监测到预设进程和预设线程均处于阻塞状态,且该显示服务线程中的关键流程正常时,判定移动终端出现黑屏故障,并将黑屏故障信息输出至特征日志文件,便于开发人员在对移动终端进行黑屏原因的检测定位时,查询特征日志文件,从而快速准确的定位黑屏原因,极大的降低人力成本和时间成本。
附图说明
图1为实现本发明各个实施例的一种移动终端的硬件结构示意图;
图2为本发明移动终端的操作系统的层级示意图;
图3为本发明黑屏检测方法第一实施例的流程示意图;
图4为图3中所述根据所述关键流程监测数据、所述进程监测数据和所述线程监测数据判断所述移动终端是否出现黑屏故障步骤的细化流程示意图;
图5为本发明黑屏检测方法第二实施例的流程示意图;
图6为本发明黑屏检测方法第三实施例的流程示意图。
本发明目的的实现、功能特点及优点将结合实施例,参照附图做进一步说明。
具体实施方式
应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
在后续的描述中,使用用于表示元件的诸如“模块”、“部件”或“单元”的后缀仅为了有利于本发明的说明,其本身没有特定的意义。因此,“模块”、“部件”或“单元”可以混合地使用。
终端可以以各种形式来实施。例如,本发明中描述的终端可以包括诸如手机、平板电脑、笔记本电脑、掌上电脑、个人数字助理(Personal Digital Assistant,PDA)、便捷式媒体播放器(Portable Media Player,PMP)、导航装置、可穿戴设备、智能手环、计步器等移动终端,以及诸如数字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可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件、闪存器件、或其他易失性固态存储器件。
参照图2,其为存储程序区中存储的操作系统的层级示意图,如图2所示,该操作系统包括Loader(装载器)层、Kernel(系统内核)层、Native(本地框架)层、Framework(框架)层(包括C++Framework层和Java Framework层)和App(应用程序)层,其中,Kernel层与Native层之间还存在HAL层(硬件抽象层),该C++Framework层和Java Framework层之间还存在JNI层,该HAL层与Kernel层之间还存在SysCall层。
该Loader层包括Boot ROM(启动服务)和Boot Loader(开机初始化程序),该BootROM主要用于当移动终端处于关机状态时,长按Power(开机)键开机,引导芯片开始从固化在ROM里的预设处代码开始执行。Boot Loader为启动操作系统之前的引导程序,主要是检查RAM,初始化硬件参数等功能。
该Kernel层主要用于进行初始化进程管理、内存管理、加载Display(显示)、Camera Driver(相机驱动)和Binder Driver(Binder驱动)等相关工作,并用于创建内核工作线程kworkder、软中断线程ksoftirqd和软中断线程thermal等内核守护进程。
该Native层主要包括init孵化来的用户空间的守护进程、HAL层以及开机动画等。Init进程(由内核启动的用户级进程)会孵化出ueventd、logd、healthd、installd、adbd和lmkd等用户守护进程User Daemons;init进程还启动servicemanager(服务管家)和bootanim(开机动画)等重要服务;init进程孵化出Zygote进程,Zygote进程是操作系统的第一个Java进程,Zygote是所有Java进程的父进程,Zygote进程本身是由init进程孵化而来的。
该Framework层包括Zygote进程、System Server(系统服务)进程和MediaServer(多媒体服务)进程,其中,Zygote进程,是由init进程通过解析init.rc文件后fork生成的,Zygote进程主要包含加载ZygoteInit类、注册Zygote Socket服务端套接字、加载虚拟机、preloadClasses和preloadResouces等;System Server进程,是由Zygote进程fork而来,System Server是Zygote孵化的第一个进程,System Server负责启动和管理整个JavaFramework,包含、ActivityManager(应用程序组件)、PowerManager(电源管理组件)和WindowManagerServer(窗口管理组件)等服务;Media Server进程,是由init进程fork而来,负责启动和管理整个C++framework,包含AudioFlinger(音频服务)、Camera Service(相机服务)和MediaPlayServer(多媒体服务)等服务。
该APP层包括APP进程,每个APP进程均由Zygote进程fork生成,Zygote进程孵化出的第一个App进程是Launcher(桌面启动器),为用户看到的桌面App,Zygote进程还会创建Browser(浏览器)、Phone(电话)和Email(邮件)等App进程,每个App至少运行在一个进程上。
处理器110是移动终端的控制中心,利用各种接口和线路连接整个移动终端的各个部分,通过运行或执行存储在存储器109内的软件程序和/或模块,以及调用存储在存储器109内的数据,执行移动终端的各种功能和处理数据,从而对移动终端进行整体监控。处理器110可包括一个或多个处理单元;优选的,处理器110可集成应用处理器和调制解调处理器,其中,应用处理器主要处理操作系统、用户界面和应用程序等,调制解调处理器主要处理无线通信。可以理解的是,上述调制解调处理器也可以不集成到处理器110中。
移动终端100还可以包括给各个部件供电的电源111(比如电池),优选的,电源111可以通过电源管理系统与处理器110逻辑相连,从而通过电源管理系统实现管理充电、放电、以及功耗管理等功能。
尽管图1未示出,移动终端100还可以包括蓝牙模块等,在此不再赘述。
基于上述移动终端硬件结构,提出本发明移动终端的各个实施例。
请参照图1,在本发明移动终端的第一实施例中,该移动终端包括:存储器、处理器以及存储在所述存储器上并可在所述处理器上运行的黑屏检测程序,所述黑屏检测程序被处理器执行时实现以下步骤:
对所述移动终端的显示服务线程中的预设关键流程进行监测,以获取关键流程监测数据,并对第一预设进程进行监测,以获取进程监测数据;
对与所述显示服务线程进行交互的属于第二预设进程的预设线程进行监测,以获取线程监测数据;
根据所述关键流程监测数据、所述进程监测数据和所述线程监测数据判断所述移动终端是否出现黑屏故障;
在所述移动终端出现黑屏故障时,从所述关键流程监测数据、所述进程监测数据和所述线程监测数据中提取黑屏故障信息,并将所述黑屏故障信息输出至特征日志文件。
进一步地,所述黑屏检测程序被处理器执行时还实现以下步骤:
根据所述关键流程监测数据判断所述移动终端的显示服务线程中的预设关键流程是否处于异常状态;
在所述移动终端的显示服务线程中的预设关键流程未处于异常状态时,根据所述进程监测数据判断所述第一预设进程是否处于阻塞状态;
在所述第一预设进程处于阻塞状态时,根据所述线程监测数据判断所述预设线程是否处于阻塞状态;
在所述预设线程处于阻塞状态时,判定所述移动终端出现黑屏故障,并在所述预设线程未处于阻塞状态时,判定所述移动终端未出现黑屏故障。
进一步地,所述黑屏检测程序被处理器执行时还实现以下步骤:
从所述线程监测数据中读取所述预设线程的线程状态值,并判断所述线程状态值是否处于预设线程状态值集合;
在所述线程状态值处于预设线程状态值集合时,判定所述预设线程处于阻塞状态,并在所述线程状态值未处于预设线程状态值集合时,判定所述预设线程未处于阻塞状态。
进一步地,所述黑屏检测程序被处理器执行时还实现以下步骤:
将所述线程监测数据写入监测数据库,并以间隔预设时间从所述监测数据库中读取线程监测数据;
根据所述线程监测数据中的所述预设线程的线程状态值判断所述线程监测数据是否为冗余数据;
在所述线程监测数据为冗余数据时,从所述监测数据库中删除所述线程监测数据。
进一步地,所述黑屏检测程序被处理器执行时还实现以下步骤:
在所述移动终端出现黑屏故障时,将所述关键流程监测数据、所述进程监测数据和所述线程监测数据存储至预设存储分区;
在检测到所述移动终端处于熄屏待机状态时,对所述预设存储分区中的关键流程监测数据、进程监测数据和线程监测数据进行去冗余处理。
进一步地,所述黑屏检测程序被处理器执行时还实现以下步骤:
判断所述预设存储分区中所述关键流程监测数据、所述进程监测数据和所述线程监测数据的存储数据量是否超过预设阈值;
在所述存储数据量超过预设阈值时,从所述预设存储分区中选取待删除数据,并对所述待删除数据进行删除操作。
本发明移动终端的具体实施例与下述黑屏检测方法的各具体实施例基本相同,在此不作赘述。
进一步地,本发明还提供一种应用于图1所示的移动终端的黑屏检测方法,参照图3,图3为本发明黑屏检测方法第一实施例的流程示意图。
在本实施例中,该黑屏检测方法包括:
步骤S101,对所述移动终端的显示服务线程中的预设关键流程进行监测,以获取关键流程监测数据,并对第一预设进程进行监测,以获取进程监测数据;
步骤S102,对与所述显示服务线程进行交互的属于第二预设进程的预设线程进行监测,以获取线程监测数据;
该黑屏检测方法应用于图1所示的移动终端,该移动终端包括智能手机和平板电脑等。本发明通过梳理和标准化Java框架层中的显示服务线程,即SystemServer进程中的DisplayManagerService线程,并根据显示服务线程中显示流程的重要程度,将Java框架层中显示服务线程的显示流程划分为关键流程和非关键流程,然后对关键流程进行监测,实现显示服务线程中关键流程的异常监测,同时,对与该SystemServer进程关联的Zygote进程、SurfaceFlinger进程和MediaServer进程、以及对DisplayManagerService线程与MediaServer进程进行交互的线程,即MediaPlayerService线程、AudioFlinger线程和CameraService线程分别进行监测。该关键流程包括亮灭屏广播接收流程、亮灭屏事件上报流程、显示缓存区域读取流程和系统UI显示准备流程等。因此,本发明通过在Java框架层中部署监测进程,以独立进程的形式运行,并调整启动次序确保在Java框架层的显示服务线程、Zygote进程、SurfaceFlinger进程和MediaServer进程正式启动之前执行。此外,本发明还通过在Native层创建守护进程,用于检测Java框架层运行的监测进程是否出现异常,及发生异常后的恢复,具体地,该守护进程通过定时主动发起与监测进程进行心跳通信来判断监测进程是否正常运行,心跳通信主要是通过Native层守护进程读取监测进程的状态,根据读取到的状态来判断监测进程是否正常运行,当守护进程读取到监测进程的状态处于阻塞状态时,便进行计时,当阻塞达到预设时长时便会强制关闭该监测进程,并重新创建监测进程,确保监测进程始终处于正常工作状态。
当移动终端即将开始启动显示服务线程时,执行部署在Java框架层的SystemServer进程中的监测进程,通过该监测进程对该移动终端的显示服务线程中的预设关键流程进行监测,以获取关键流程监测数据,并对第一预设进程,即Zygote进程、SurfaceFlinger进程和MediaServer进程进行监测,以获取进程监测数据,还对与该显示服务线程进行交互的属于第二预设进程的预设线程,即MediaPlayerService线程、AudioFlinger线程和CameraService线程进行监测,以获取线程监测数据。该预设关键流程包括亮灭屏广播接收流程、亮灭屏事件上报流程、显示缓存区域读取流程和系统UI显示准备流程等,该关键流程监测数据包括监测时间、关键流程标识、操作动作、操作动作的执行时间、操作动作执行结果和显示状态等,该进程监测数据包括Zygote进程、SurfaceFlinger进程和MediaServer进程的进程名称、线程名称、进程ID、线程ID、线程状态值、初始化时间、执行时间和同步锁信息等,该线程监测数据包括MediaPlayerService线程、AudioFlinger线程和CameraService线程的进程名称、线程名称、进程ID、线程ID、线程状态值、初始化时间、执行时间和同步锁信息等。
具体地,该移动终端对亮灭屏广播接收流程、亮灭屏事件上报流程、显示缓存区域读取流程和系统UI显示准备流程等进行监测,即监测用户触发的亮灭屏操作是否被移动终端成功执行,即从寄存器中读取执行亮灭屏操作的状态返回值,判断该状态返回值是否与之前的状态返回值相同,如果该状态返回值与之前的状态返回值相同,则表示亮灭屏广播接收流程处于异常状态,如果该状态返回值与之前的状态返回值不同,则表示亮灭屏广播接收流程处于正常状态;监测用户基于电源按键触发的亮灭屏事件是否上报成功,如果该亮灭屏事件上报成功,则表示亮灭屏事件上报流程处于正常状态,如果该亮灭屏事件上报失败,则表示量灭屏亮灭屏事件上报流程处于异常状态;监测显示缓存区域中已合成数据和待合成数据的相似度是否大于预设阈值,如果显示缓存区域中已合成数据和待合成数据的相似度大于或等于预设阈值,则表示显示缓存区域读取流程处于正常状态,如果显示缓存区域中已合成数据和待合成数据的相似度小于预设阈值,则表示显示缓存区域读取流程处于异常状态;监测系统UI的状态值是否为预设状态值,如果系统UI的状态值为预设状态值,则表示系统UI显示准备流程处于异常状态,如果系统UI的状态值不为预设状态值,则表示系统UI显示准备流程处于正常状态。
步骤S103,根据所述关键流程监测数据、所述进程监测数据和所述线程监测数据判断所述移动终端是否出现黑屏故障;
该移动终端在获取到关键流程监测数据、进程监测数据和线程监测数据之后,根据该关键流程监测数据、该进程监测数据和该线程监测数据判断该移动终端是否出现黑屏故障。
具体地,参照图4,图4为图3中步骤该S103的细化流程示意图,该步骤S103包括:
步骤S1031,根据所述关键流程监测数据判断所述移动终端的显示服务线程中的预设关键流程是否处于异常状态;
该移动终端根据该关键流程监测数据判断该移动终端的显示服务线程中的预设关键流程是否出现异常,即判断该关键流程监测数据中是否包含预设信息,如果该关键流程监测数据中包含预设信息,则判定移动终端的显示服务线程中的预设关键流程出现异常,如果该关键流程监测数据中未包含预设信息,则判定移动终端的显示服务线程中的预设关键流程未出现异常。该预设信息包括表示亮灭屏操作的状态返回值与之前的状态返回值相同的信息、表示亮灭屏事件上报失败的信息、表示显示缓存区域中已合成数据和待合成数据的相似度小于预设阈值的信息和表示系统UI的状态值为预设状态值的信息。需要说明的是,该预设信息可由本领域技术人员基于实际情况进行设置,本实施例对此不作具体说明。
步骤S1032,在所述移动终端的显示服务线程中的预设关键流程未处于异常状态时,根据所述进程监测数据判断所述第一预设进程是否处于阻塞状态;
该移动终端在该显示服务线程中的预设关键流程未出现异常时,根据该进程监测数据判断该第一预设进程是否处于阻塞状态,即从该进程监测数据中读取该第一预设进程,即Zygote进程、SurfaceFlinger进程和MediaServer进程的进程状态值,并判断该进程状态值是否处于预设进程状态值,如果该进程状态值处于预设进程状态值,则判定该第一预设进程处于阻塞状态,如果该进程状态值不处于预设进程状态值,则判定该第一预设进程未处于阻塞状态,即Zygote进程、SurfaceFlinger进程和MediaServer进程中的至少一个进程处于阻塞状态。该进程状态值包括Blocked、Held by、Active和WaitingTimeout等,该预设进程状态值为Blocked和Held by组成的集合。
步骤S1033,在所述第一预设进程处于阻塞状态时,根据所述线程监测数据判断所述预设线程是否处于阻塞状态;
该移动终端在第一预设进程处于阻塞状态,即Zygote进程、SurfaceFlinger进程和MediaServer进程中的至少一个进程处于阻塞状态时,根据该线程监测数据判断该预设线程是否处于阻塞状态,即根据该线程监测数据判断MediaPlayerService线程、AudioFlinger线程和/或CameraService线程是否处于阻塞状态。
可选地,在本实施例中,该步骤S1033包括:
从所述线程监测数据中读取所述预设线程的线程状态值,并判断所述线程状态值是否处于预设线程状态值集合;
在所述线程状态值处于预设线程状态值集合时,判定所述预设线程处于阻塞状态,并在所述线程状态值未处于预设线程状态值集合时,判定所述预设线程未处于阻塞状态。
该移动终端从该线程监测数据中读取该预设线程的线程状态值,即读取MediaPlayerService线程、AudioFlinger线程和/或CameraService线程的线程状态值,并判断该线程状态值是否处于预设线程状态值集合,如果该线程状态值处于预设线程状态值集合,则判定预设线程处于阻塞状态,如果该线程状态值未处于预设线程状态值集合,则判定预设线程未处于阻塞状态,即在MediaPlayerService线程、AudioFlinger线程和CameraService线程中的至少一个线程出现阻塞时,可确定显示服务线程,即DisplayManagerService线程与MediaServer进程之间的交互出现异常,该线程状态值包括Blocked、Held by、Active和Waiting Timeout等,该预设线程状态值集合为Blocked和Heldby组成的集合。
步骤S1034,在所述预设线程处于阻塞状态时,判定所述移动终端出现黑屏故障,并在所述预设线程未处于阻塞状态时,判定所述移动终端未出现黑屏故障。
该移动终端在该预设线程,即MediaPlayerService线程、AudioFlinger线程和CameraService线程中的至少一个线程处于阻塞状态时,判定该移动终端出现黑屏故障,在该预设线程,即MediaPlayerService线程、AudioFlinger线程和CameraService线程均不处于阻塞状态时,判定该移动终端未出现黑屏故障。在具体实施中,当该移动终端在该显示服务线程中的预设关键流程,即灭屏广播接收流程、亮灭屏事件上报流程、显示缓存区域读取流程和系统UI显示准备流程中的任一流程出现异常时,可判定移动终端出现黑屏故障。在具体实施中,本发明还对与该显示服务线程进行交互的属于该SurfaceFlinger的线程进行监测,在Zygote进程、SurfaceFlinger进程和MediaServer进程中的至少一个进程处于阻塞状态的前提下,在监测到与该显示服务线程进行交互的属于该SurfaceFlinger的线程处于阻塞状态时,可判定移动终端出现故障,同时,还在Zygote进程、SurfaceFlinger进程和MediaServer进程中的至少一个进程处于阻塞状态的前提下、MediaPlayerService线程、AudioFlinger线程和CameraService线程中的至少一个线程处于阻塞状态和/或与该显示服务线程进行交互的属于该SurfaceFlinger的线程处于阻塞状态时,可判定移动终端出现黑屏故障。
步骤S104,在所述移动终端出现黑屏故障时,从所述关键流程监测数据、所述进程监测数据和所述线程监测数据中提取黑屏故障信息,并将所述黑屏故障信息输出至特征日志文件。
在移动终端出现黑屏故障时,从该关键流程监测数据、该进程监测数据和该线程监测数据提取黑屏故障信息,并将该黑屏故障信息输出至特征日志文件,具体地,移动终端单独创建一个线程将黑屏故障信息输出到Debugerd进程,由Debugerd进程将黑屏故障信息定向输出至具有Debugerd权限处理的特征日志文件中。该黑屏故障信息包括出现异常的显示流程和出现阻塞的线程信息。在具体实施中,在移动终端出现黑屏故障时,根据该关键流程监测数据、该进程监测数据和该线程监测数据确定阻塞进程和阻塞线程,然后将该阻塞进程、该阻塞线程和预设关键进程(MediaServer进程、SurfaceFlinger进程、SystemServer进程)的调度优先级设置为最高调用优先级,并通过CPU大核调度该阻塞进程、该阻塞线程和预设关键进程。
在另一具体实施中,该特征日志文件存储在预设存储区域中,该移动终端定时从预设存储区域中读取特征日志文件,并判断该特征日志文件的比特数是否大于或等于预设比特数,然后在该特征日志文件的比特数大于或等于预设比特数时,将预设存储区域中的特征日志文件上传至预设云端进行存储,并从预设存储区域中删除上传成功的特征日志文件,能够在特征日志文件超过一定比特数,将特征日志文件上传至云端进行存储,提高磁盘利用率。
在本实施例中,本发明通过对移动终端的显示服务线程中的关键流程进行监测、对预设进程进行监测、以及对与该显示服务线程进行交互的预设线程进行监测,并在监测到预设进程和预设线程均处于阻塞状态,且该显示服务线程中的关键流程正常时,判定移动终端出现黑屏故障,并将黑屏故障信息输出至特征日志文件,便于开发人员在对移动终端进行黑屏原因的检测定位时,查询特征日志文件,从而快速准确的定位黑屏原因,极大的降低人力成本和时间成本。
进一步地,参照图5,基于上述第一实施例,提出了本发明黑屏检测方法的第二实施例,与前述实施例的区别在于,该步骤S102之后,该黑屏检测方法还包括:
步骤S105,将所述线程监测数据写入监测数据库,并以间隔预设时间从所述监测数据库中读取线程监测数据;
步骤S106,根据所述线程监测数据中的所述预设线程的线程状态值判断所述线程监测数据是否为冗余数据;
步骤S107,在所述线程监测数据为冗余数据时,从所述监测数据库中删除所述线程监测数据。
需要说明的是,本发明基于前述实施例,提出了一种线程监测数据的具体删除方式,以下仅对此进行说明,其它可参照前述实施例。
该移动终端对与该显示服务线程进行交互的属于第二预设进程的预设线程进行监测,以获取线程监测数据之后,将该线程监测数据写入监测数据库,并以间隔预设时间从该监测数据库中读取线程监测数据,然后根据该线程监测数据中的预设线程的线程状态值判断该线程监测数据是否为冗余数据,在该线程监测数据为冗余数据时,从该监测数据库中删除该线程监测数据。
具体地,从该线程监测数据中获取预设线程的线程状态值,即从该线程监测数据中获取MediaPlayerService线程、AudioFlinger线程和CameraService线程的线程状态值,并判断MediaPlayerService线程、AudioFlinger线程和CameraService线程的线程状态值中是否存在至少一个线程状态值处于预设线程状态值集合,如果该MediaPlayerService线程、AudioFlinger线程和CameraService线程的线程状态值均不处于预设线程状态值集合,则可以判定该线程监测数据为冗余数据,因此,从该监测数据库中删除该线程监测数据,如果MediaPlayerService线程、AudioFlinger线程和CameraService线程的线程状态值中存在至少一个线程状态值处于预设线程状态值集合,则可以判定该线程监测数据不为冗余数据,则保留该线程监测数据。该预设线程状态值集合为Blocked和Held by组成的集合。对进程监测数据的去冗余方式,可参照前述线程监测数据的去冗余方式,在此不再赘述。
在本实施例中,本发明以间隔预设时间对线程监测数据进行去冗余处理,能够有效的减少存储记录的数据,降低磁盘空间占用,提高磁盘利用率。
进一步地,参照图6,基于上述第一或第二实施例,提出了本发明黑屏检测方法的第三实施例,与前述实施例的区别在于,该步骤S102之后,该黑屏检测方法还包括:
步骤S108,在所述移动终端出现黑屏故障时,将所述关键流程监测数据、所述进程监测数据和所述线程监测数据存储至预设存储分区;
步骤S109,在检测到所述移动终端处于熄屏待机状态时,对所述预设存储分区中的关键流程监测数据、进程监测数据和线程监测数据进行去冗余处理。
需要说明的是,本发明基于前述实施例提出了一种数据去冗余的具体方式,以下仅对此进行说明,其它可参照前述实施例。
该移动终端在出现黑屏故障时,将该关键流程监测数据、该进程监测数据和该线程监测数据存储至预设存储分区,然后在检测到移动终端处于熄屏待机状态时,对该预设存储分区中的关键流程监测数据、进程监测数据和线程监测数据进行去冗余处理,并存储去冗余后的关键流程监测数据、进程监测数据和线程监测数据。在具体实施中,该移动终端还可以在预设时间内对该预设存储分区中的关键流程监测数据、进程监测数据和线程监测数据进行去冗余处理,预设时间为通过实验确定的合理去冗余间隔时间,在此间隔时间内,需要去冗余的数据不会太多也不会太少,导致花费的时间过长或去冗余过于频繁。去冗余的过程为将预设时间内将该预设存储分区中的关键流程监测数据、进程监测数据和线程监测数据整合为一条信息进行存储,此条信息包括导致黑屏的原因类型,出现的时间点,以及各种类型出现的次数。
在本实施例中,本发明通过在移动终端处于熄屏待机状态时,对关键流程监测数据、进程监测数据和线程监测数据进行去冗余,能够有效的减少存储记录的数据,降低磁盘空间占用,提高磁盘利用率。
进一步地,基于上述第三实施例,提出了本发明黑屏检测方法的第四实施例,与前述实施例的区别在于,该步骤步骤S109之后,该黑屏检测方法还包括:
判断所述预设存储分区中所述关键流程监测数据、所述进程监测数据和所述线程监测数据的存储数据量是否超过预设阈值;
在所述存储数据量超过预设阈值时,从所述预设存储分区中选取待删除数据,并对所述待删除数据进行删除操作。
需要说明的是,本发明基于前述实施例提出了一种数据存储方式,以下仅对此进行说明,其它可参照前述实施例。
具体地,移动终端中的存储单元分为多个存储分区,每个存储分区用于存储不同的数据,且每个存储区间的容量一定,即所能存储的数据量一定。相应的,用于存储关键流程监测数据、进程监测数据和线程监测数据的存储分区的容量也一定,当在预设时间内将关键流程监测数据、进程监测数据和线程监测数据存储到此存储区间内时,其存储的数据量不断增加,有可能超出其容量。从而在将关键流程监测数据、进程监测数据和线程监测数据进行去冗余处理存储后,判断存储的关键流程监测数据、进程监测数据和线程监测数据的存储数据量是否超过预设阈值,此预设阈值即为用于存储关键流程监测数据、进程监测数据和线程监测数据的存储区域的容量大小。在关键流程监测数据、进程监测数据和线程监测数据的存储数据量超过预设阈值时,则说明此存储分区的容量被用完,不能再进行数据存储,需要对其存储的关键流程监测数据、进程监测数据和线程监测数据进行删除操作。从存储的关键流程监测数据、进程监测数据和线程监测数据中选取待删除信息,将此待删除信息进行删除操作。其中选取的原则可根据时间顺序,时间顺序越靠前,表明此关键流程监测数据、进程监测数据和线程监测数据离现在的时间越久远,可参考的意义不大,从而选取其为待删除信息进行删除。
在本实施例中,本发明能够在关键流程监测数据、进程监测数据和线程监测数据的存储数据量超过预设阈值时,对关键流程监测数据、进程监测数据和线程监测数据进行有选择的删除,提高存储空间利用率。
此外,本发明实施例还提出一种计算机可读存储介质,所述计算机可读存储介质上存储有黑屏检测程序,所述黑屏检测程序被处理器执行时实现以下步骤:
对所述移动终端的显示服务线程中的预设关键流程进行监测,以获取关键流程监测数据,并对第一预设进程进行监测,以获取进程监测数据;
对与所述显示服务线程进行交互的属于第二预设进程的预设线程进行监测,以获取线程监测数据;
根据所述关键流程监测数据、所述进程监测数据和所述线程监测数据判断所述移动终端是否出现黑屏故障;
在所述移动终端出现黑屏故障时,从所述关键流程监测数据、所述进程监测数据和所述线程监测数据中提取黑屏故障信息,并将所述黑屏故障信息输出至特征日志文件。
进一步地,所述黑屏检测程序被处理器执行时还实现以下步骤:
根据所述关键流程监测数据判断所述移动终端的显示服务线程中的预设关键流程是否处于异常状态;
在所述移动终端的显示服务线程中的预设关键流程未处于异常状态时,根据所述进程监测数据判断所述第一预设进程是否处于阻塞状态;
在所述第一预设进程处于阻塞状态时,根据所述线程监测数据判断所述预设线程是否处于阻塞状态;
在所述预设线程处于阻塞状态时,判定所述移动终端出现黑屏故障,并在所述预设线程未处于阻塞状态时,判定所述移动终端未出现黑屏故障。
进一步地,所述黑屏检测程序被处理器执行时还实现以下步骤:
从所述线程监测数据中读取所述预设线程的线程状态值,并判断所述线程状态值是否处于预设线程状态值集合;
在所述线程状态值处于预设线程状态值集合时,判定所述预设线程处于阻塞状态,并在所述线程状态值未处于预设线程状态值集合时,判定所述预设线程未处于阻塞状态。
进一步地,所述黑屏检测程序被处理器执行时还实现以下步骤:
将所述线程监测数据写入监测数据库,并以间隔预设时间从所述监测数据库中读取线程监测数据;
根据所述线程监测数据中的所述预设线程的线程状态值判断所述线程监测数据是否为冗余数据;
在所述线程监测数据为冗余数据时,从所述监测数据库中删除所述线程监测数据。
进一步地,所述黑屏检测程序被处理器执行时还实现以下步骤:
在所述移动终端出现黑屏故障时,将所述关键流程监测数据、所述进程监测数据和所述线程监测数据存储至预设存储分区;
在检测到所述移动终端处于熄屏待机状态时,对所述预设存储分区中的关键流程监测数据、进程监测数据和线程监测数据进行去冗余处理。
进一步地,所述黑屏检测程序被处理器执行时还实现以下步骤:
判断所述预设存储分区中所述关键流程监测数据、所述进程监测数据和所述线程监测数据的存储数据量是否超过预设阈值;
在所述存储数据量超过预设阈值时,从所述预设存储分区中选取待删除数据,并对所述待删除数据进行删除操作。
本发明计算机可读存储介质的具体实施例与上述黑屏检测方法的各具体实施例基本相同,在此不作赘述。
需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者系统不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者系统所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、方法、物品或者系统中还存在另外的相同要素。
上述本发明实施例序号仅仅为了描述,不代表实施例的优劣。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在如上所述的一个计算机存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端设备(可以是手机,计算机,服务器,空调器,或者网络设备等)执行本发明各个实施例所述的方法。
以上仅为本发明的优选实施例,并非因此限制本发明的专利范围,凡是利用本发明说明书及附图内容所作的等效结构或等效流程变换,或直接或间接运用在其他相关的技术领域,均同理包括在本发明的专利保护范围内。

Claims (8)

1.一种黑屏检测方法,其特征在于,所述黑屏检测方法应用于移动终端,所述黑屏检测方法包括以下步骤:
对所述移动终端的显示服务线程中的预设关键流程进行监测,以获取关键流程监测数据,并对第一预设进程进行监测,以获取进程监测数据;
对与所述显示服务线程进行交互的属于第二预设进程的预设线程进行监测,以获取线程监测数据;
根据所述关键流程监测数据、所述进程监测数据和所述线程监测数据判断所述移动终端是否出现黑屏故障;
在所述移动终端出现黑屏故障时,从所述关键流程监测数据、所述进程监测数据和所述线程监测数据中提取黑屏故障信息,并将所述黑屏故障信息输出至特征日志文件;
所述根据所述关键流程监测数据、所述进程监测数据和所述线程监测数据判断所述移动终端是否出现黑屏故障的步骤包括:
根据所述关键流程监测数据判断所述移动终端的显示服务线程中的预设关键流程是否处于异常状态;
在所述移动终端的显示服务线程中的预设关键流程未处于异常状态时,根据所述进程监测数据判断所述第一预设进程是否处于阻塞状态;
在所述第一预设进程处于阻塞状态时,根据所述线程监测数据判断所述预设线程是否处于阻塞状态;
在所述预设线程处于阻塞状态时,判定所述移动终端出现黑屏故障,并在所述预设线程未处于阻塞状态时,判定所述移动终端未出现黑屏故障。
2.如权利要求1所述的黑屏检测方法,其特征在于,所述根据所述线程监测数据判断所述预设线程是否处于阻塞状态的步骤包括:
从所述线程监测数据中读取所述预设线程的线程状态值,并判断所述线程状态值是否处于预设线程状态值集合;
在所述线程状态值处于预设线程状态值集合时,判定所述预设线程处于阻塞状态,并在所述线程状态值未处于预设线程状态值集合时,判定所述预设线程未处于阻塞状态。
3.如权利要求1所述的黑屏检测方法,其特征在于,所述对与所述显示服务线程进行交互的属于第二预设进程的预设线程进行监测,以获取线程监测数据的步骤之后,所述黑屏检测方法还包括:
将所述线程监测数据写入监测数据库,并以间隔预设时间从所述监测数据库中读取线程监测数据;
根据所述线程监测数据中的所述预设线程的线程状态值判断所述线程监测数据是否为冗余数据;
在所述线程监测数据为冗余数据时,从所述监测数据库中删除所述线程监测数据。
4.如权利要求1-3中任一项所述的黑屏检测方法,其特征在于,所述根据所述关键流程监测数据、所述进程监测数据和所述线程监测数据判断所述移动终端是否出现黑屏故障的步骤之后,所述黑屏检测方法还包括:
在所述移动终端出现黑屏故障时,将所述关键流程监测数据、所述进程监测数据和所述线程监测数据存储至预设存储分区;
在检测到所述移动终端处于熄屏待机状态时,对所述预设存储分区中的关键流程监测数据、进程监测数据和线程监测数据进行去冗余处理。
5.如权利要求4所述的黑屏检测方法,其特征在于,所述对所述预设存储分区中的关键流程监测数据、进程监测数据和线程监测数据进行去冗余处理的步骤之后,所述黑屏检测方法还包括:
判断所述预设存储分区中所述关键流程监测数据、所述进程监测数据和所述线程监测数据的存储数据量是否超过预设阈值;
在所述存储数据量超过预设阈值时,从所述预设存储分区中选取待删除数据,并对所述待删除数据进行删除操作。
6.一种移动终端,其特征在于,所述移动终端包括:存储器、处理器及存储在所述存储器上并可在所述处理器上运行的黑屏检测程序,所述黑屏检测程序被所述处理器执行时实现以下步骤:
对所述移动终端的显示服务线程中的预设关键流程进行监测,以获取关键流程监测数据,并对第一预设进程进行监测,以获取进程监测数据;
对与所述显示服务线程进行交互的属于第二预设进程的预设线程进行监测,以获取线程监测数据;
根据所述关键流程监测数据、所述进程监测数据和所述线程监测数据判断所述移动终端是否出现黑屏故障;
在所述移动终端出现黑屏故障时,从所述关键流程监测数据、所述进程监测数据和所述线程监测数据中提取黑屏故障信息,并将所述黑屏故障信息输出至特征日志文件;
所述黑屏检测程序被所述处理器执行时还实现以下步骤:
根据所述关键流程监测数据判断所述移动终端的显示服务线程中的预设关键流程是否处于异常状态;
在所述移动终端的显示服务线程中的预设关键流程未处于异常状态时,根据所述进程监测数据判断所述第一预设进程是否处于阻塞状态;
在所述第一预设进程处于阻塞状态时,根据所述线程监测数据判断所述预设线程是否处于阻塞状态;
在所述预设线程处于阻塞状态时,判定所述移动终端出现黑屏故障,并在所述预设线程未处于阻塞状态时,判定所述移动终端未出现黑屏故障。
7.如权利要求6所述的移动终端,其特征在于,所述黑屏检测程序被所述处理器执行时还实现如权利要求2至5中任一项所述的黑屏检测方法的步骤。
8.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质上存储有黑屏检测程序,所述黑屏检测程序被处理器执行时实现如权利要求1至5中任一项所述的黑屏检测方法的步骤。
CN201711055461.9A 2017-10-31 2017-10-31 黑屏检测方法、移动终端及计算机可读存储介质 Active CN107818036B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201711055461.9A CN107818036B (zh) 2017-10-31 2017-10-31 黑屏检测方法、移动终端及计算机可读存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201711055461.9A CN107818036B (zh) 2017-10-31 2017-10-31 黑屏检测方法、移动终端及计算机可读存储介质

Publications (2)

Publication Number Publication Date
CN107818036A CN107818036A (zh) 2018-03-20
CN107818036B true CN107818036B (zh) 2021-01-15

Family

ID=61603687

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201711055461.9A Active CN107818036B (zh) 2017-10-31 2017-10-31 黑屏检测方法、移动终端及计算机可读存储介质

Country Status (1)

Country Link
CN (1) CN107818036B (zh)

Families Citing this family (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110221928B (zh) * 2019-06-11 2021-06-04 Oppo广东移动通信有限公司 信息记录方法、装置、终端及存储介质
CN110377480A (zh) * 2019-06-17 2019-10-25 百度(中国)有限公司 监测处理方法、装置、系统及计算机可读存储介质
CN112731102B (zh) * 2020-12-23 2021-12-21 四川长虹电器股份有限公司 一种液晶电视背光故障检测方法

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101221585A (zh) * 2008-02-03 2008-07-16 华为技术有限公司 数据存储方法及装置
CN105302637A (zh) * 2015-10-13 2016-02-03 广东欧珀移动通信有限公司 系统进程运行异常引起卡顿的恢复方法、装置及移动终端
CN105930208A (zh) * 2016-04-01 2016-09-07 广州华多网络科技有限公司 一种线程调度方法及线程调度装置
CN106649017A (zh) * 2016-12-30 2017-05-10 珠海市魅族科技有限公司 一种屏幕显示异常的处理方法及移动终端
CN106897197A (zh) * 2015-12-17 2017-06-27 阿里巴巴集团控股有限公司 错误日志的去重方法及装置

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9529996B2 (en) * 2011-10-11 2016-12-27 Citrix Systems, Inc. Controlling mobile device access to enterprise resources

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101221585A (zh) * 2008-02-03 2008-07-16 华为技术有限公司 数据存储方法及装置
CN105302637A (zh) * 2015-10-13 2016-02-03 广东欧珀移动通信有限公司 系统进程运行异常引起卡顿的恢复方法、装置及移动终端
CN106897197A (zh) * 2015-12-17 2017-06-27 阿里巴巴集团控股有限公司 错误日志的去重方法及装置
CN105930208A (zh) * 2016-04-01 2016-09-07 广州华多网络科技有限公司 一种线程调度方法及线程调度装置
CN106649017A (zh) * 2016-12-30 2017-05-10 珠海市魅族科技有限公司 一种屏幕显示异常的处理方法及移动终端

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
"Android系统启动过程";网友;《新浪微博http://blog.sina.com.cn/s/blog_49f62c3501010fj9.html》;20111105;全文 *

Also Published As

Publication number Publication date
CN107818036A (zh) 2018-03-20

Similar Documents

Publication Publication Date Title
CN107678876B (zh) 冻屏监测与解决方法、移动终端及计算机可读存储介质
CN107276789B (zh) 日志上传方法、装置及计算机可读存储介质
CN107590057B (zh) 冻屏监测与解决方法、移动终端及计算机可读存储介质
CN107861817B (zh) 基于线程阻塞的内存优化方法、移动终端及可读存储介质
CN107807861B (zh) 冻屏解决方法、移动终端及计算机可读存储介质
CN107704133B (zh) 冻屏监测与解决方法、移动终端及计算机可读存储介质
CN108040159B (zh) 基于硬件驱动的重启定位方法、移动终端及可读存储介质
CN107885635B (zh) 黑屏检测方法、移动终端及计算机可读存储介质
CN107704363B (zh) 冻屏监测方法、移动终端及计算机可读存储介质
CN107908492B (zh) 黑屏检测方法、移动终端及计算机可读存储介质
CN108073458B (zh) 内存回收方法、移动终端及计算机可读存储介质
CN107766222B (zh) 黑屏检测方法、移动终端及计算机可读存储介质
CN108052390B (zh) 基于线程阻塞的内存清理方法、移动终端及可读存储介质
CN107765922B (zh) 卡屏检测与解决方法、移动终端及计算机可读存储介质
CN109522278B (zh) 一种文件存储方法及终端设备
CN107908491B (zh) 卡屏检测与解决方法、移动终端及计算机可读存储介质
CN107967177B (zh) 基于核心进程的内存优化方法、移动终端及可读存储介质
CN107818036B (zh) 黑屏检测方法、移动终端及计算机可读存储介质
CN107704332B (zh) 冻屏解决方法、移动终端及计算机可读存储介质
CN107832191B (zh) 黑屏检测方法、移动终端及计算机可读存储介质
CN107872367B (zh) 黑屏检测方法、移动终端及计算机可读存储介质
CN107861826B (zh) 冻屏监测与解决方法、移动终端及计算机可读存储介质
CN107908478B (zh) 内存清理方法、移动终端及计算机可读存储介质
CN107861827B (zh) 卡屏检测方法、移动终端及计算机可读存储介质
CN108089935B (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