信息处理方法及电子设备的制造方法

文档序号:10686952阅读:515来源:国知局
信息处理方法及电子设备的制造方法
【专利摘要】本实施例公开了一种信息处理方法及电子设备,所述信息处理方法包括:解析日志中的日志信息,提取事件信息;封装所述事件信息形成操作事件;其中,所述操作事件用于触发应用组件执行对应的操作;利用应用组件响应所述操作事件,以重现故障场景和程序运行状态。这样通过解析日志,获得触发响应组件执行对应操作的操作事件,相当于响应组件以历史操作时间的事件信息再次执行对应的操作,从而可以用于故障场景的重现和程序状态运行。
【专利说明】
信息处理方法及电子设备
技术领域
[0001]本发明涉及信息技术领域,尤其涉及一种信息处理方法及电子设备。
【背景技术】
[0002]日志Log将记录程序运行的相关信息,可作为是调试程序及监视程序运行的一种重要信息,如此,根据日志可以定位出程序在运行过程中出现的问题,或根据日志监控程序的运行状态。
[0003]在基于日志的程序故障Bug分析时,一般是由程序员或调试工作人员,逐行阅读,人工一步步的推断用户或者测试人员的操作场景以及程序的运行状态,耗时费力。测试人员或用户短短几十秒的操作,可能产生上万行的日志信息,从这么庞大的信息中,人工定位问题点效率十分低。

【发明内容】

[0004]有鉴于此,本发明实施例期望提供一种信息处理方法及电子设备,至少部分解决现有技术中调试繁琐、调试效率或调试成本高的特点。
[0005]为达到上述目的,本发明的技术方案是这样实现的:
[0006]本发明实施例第一方面提供一种信息处理方法,包括:
[0007]解析日志中的日志信息,提取事件信息;
[0008]封装所述事件信息形成操作事件;其中,所述操作事件用于触发应用组件执行对应的操作;
[0009]利用应用组件响应所述操作事件,以重现故障场景和程序运行状态。
[0010]基于上述方案,所述方法还包括:
[0011 ]依据所述日志信息的输出格式,配置解析规则;
[0012]所述解析日志中的日志信息,提取事件信息,包括:
[0013]利用所述解析规则,提取所述事件信息。
[0014]基于上述方案,所述利用所述解析规则,提取所述事件信息,包括:
[0015]利用正则表达式,从所述日志信息中提取所述事件信息。
[0016]基于上述方案,所述解析日志中的日志信息,提取事件信息,包括:
[0017]提取历史事件的发生时间、事件类型和操作参数;
[0018]所述封装所述事件信息形成操作事件,包括:
[0019]根据所述发生时间,确定所述操作事件的操作时序;所述操作时序包括各个操作发生的先后顺序及相邻两个所述操作间的时间间隔;
[0020]依据所述操作时序及所述事件类型构建及所述操作参数,构建所述操作事件。
[0021]基于上述方案,所述方法还包括:
[0022]启动调试应用的应用界面;
[0023]检测应用于所述应用界面的操作指示;
[0024]所述解析日志中的日志信息,提取事件信息,包括:
[0025]当所述操作指示进行程序调试时,所述调试应用读取并解析所述日志信息,以提取所述事件信息。
[0026]本发明实施例第二方面提供一种电子设备,包括:
[0027]解析单元,用于解析日志中的日志信息,提取事件信息;
[0028]封装单元,用于封装所述事件信息形成操作事件;其中,所述操作事件用于触发应用组件执行对应的操作;
[0029]响应单元,用于利用应用组件响应所述操作事件,以重现故障场景和程序运行状
??τ O
[0030]基于上述方案,所述电子设备还包括:
[0031 ]配置单元,用于依据所述日志信息的输出格式,配置解析规则;
[0032]所述解析单元,用于利用所述解析规则,提取所述事件信息。
[0033]基于上述方案,所述解析单元,具体用于利用正则表达式,从所述日志信息中提取所述事件ig息。
[0034]基于上述方案,所述解析单元,具体用于提取历史事件的发生时间、事件类型和操作参数;
[0035]所述封装单元,具体用于根据所述发生时间,确定所述操作事件的操作时序;所述操作时序包括各个操作发生的先后顺序及相邻两个所述操作间的时间间隔;依据所述操作时序及所述事件类型构建及所述操作参数,构建所述操作事件。
[0036]基于上述方案,所述电子设备还包括:
[0037]启动单元,用于启动调试应用的应用界面;
[0038]检测单元,用于检测应用于所述应用界面的操作指示;
[0039]所述解析单元,用于当所述操作指示进行程序调试时,所述调试应用读取并解析所述日志信息,以提取所述事件信息。
[0040]本发明实施例提供的信息处理方法及电子设备,在进行调试时,通过自动解析日志信息,提取出操作事件,而操作事件被注入到电子设备中,经分发后可以直接由响应组件通过执行对应的操作来实现,相当于实现了日志中历史事件的重新响应,就可实现故障场景的重现和程序状态运行,在整个调试过程中,不依赖调试人员,更不取决于调试人员的业务能力,提升了调试效率,降低了人力成本和时间成本。
【附图说明】
[0041 ]图1为本发明实施例提供了一种移动终端的结构示意图;
[0042]图2为图1所述移动终端的通信系统的结构示意图;
[0043]图3为本发明实施例提供的第一种信息处理方法的流程示意图;
[0044]图4为本发明实施例提供的一种日志信息的显示效果示意图;
[0045]图5为本发明实施例提供的一种移动终端的结构示意图;
[0046]图6为本发明实施例提供的第二种信息处理方法的流程示意图;
[0047]图7为本发明实施例提供的第三种信息处理方法的流程示意图;
[0048]图8为本发明实施例提供的第四种信息处理方法的流程示意图。
【具体实施方式】
[0049]以下结合说明书附图及具体实施例对本发明的技术方案做进一步的详细阐述。
[0050]应当理解,此处所描述的具体实施例仅仅用以解释本发明的技术方案,并不用于限定本发明的保护范围。
[0051]现在将参考附图描述实现本发明各个实施例的移动终端。在后续的描述中,使用用于表示元件的诸如“模块”、“部件”或“单元”的后缀仅为了有利于本发明的说明,其本身并没有特定的意义。因此,“模块”与“部件”可以混合地使用。
[0052]移动终端可以以各种形式来实施。例如,本发明中描述的终端可以包括诸如移动电话、智能电话、笔记本电脑、数字广播接收器、个人数字助理(PDA)、平板电脑(PAD)、便携式多媒体播放器(PMP)、导航装置等等的移动终端以及诸如数字TV、台式计算机等等的固定终端。下面,假设终端是移动终端。然而,本领域技术人员将理解的是,除了特别用于移动目的的元件之外,根据本发明的实施方式的构造也能够应用于固定类型的终端。
[0053]图1为实现本发明各个实施例的移动终端100的硬件结构示意,如图1所示,移动终端100可以包括无线通信单元110、音频/视频(A/V)输入单元120、用户输入单元130、输出单元150、存储器160、接口单元170、控制器180和电源单元190等等。图1示出了具有各种组件的移动终端100,但是应理解的是,并不要求实施所有示出的组件。可以替代地实施更多或更少的组件。将在下面详细描述移动终端100的元件。
[0054]无线通信单元110通常包括一个或多个组件,其允许移动终端100与无线通信系统或网络之间的无线电通信。例如,无线通信单元110可以包括广播接收模块111、移动通信模块112、无线互联网模块113、短程通信模块114和位置信息模块115中的至少一个。
[0055]广播接收模块111经由广播信道从外部广播管理服务器接收广播信号和/或广播相关信息。广播信道可以包括卫星信道和/或地面信道。广播管理服务器可以是生成并发送广播信号和/或广播相关信息的服务器或者接收之前生成的广播信号和/或广播相关信息并且将其发送给终端的服务器。广播信号可以包括TV广播信号、无线电广播信号、数据广播信号等等。而且,广播信号可以进一步包括与TV或无线电广播信号组合的广播信号。广播相关信息也可以经由移动通信网络提供,并且在该情况下,广播相关信息可以由移动通信模块112来接收。广播信号可以以各种形式存在,例如,其可以以数字多媒体广播(DMB)的电子节目指南(EPG)、数字视频广播手持(DVB-H)的电子服务指南(ESG)等等的形式而存在。广播接收模块111可以通过使用各种类型的广播系统接收信号广播。特别地,广播接收模块111可以通过使用诸如多媒体广播-地面(DMB-T)、数字多媒体广播-卫星(DMB-S)、数字视频广播-手持(DVB-H),前向链路媒体(MediaFLO?)的数据广播系统、地面数字广播综合服务(ISDB-T)等等的数字广播系统接收数字广播。广播接收模块111可以被构造为适合提供广播信号的各种广播系统以及上述数字广播系统。经由广播接收模块111接收的广播信号和/或广播相关信息可以存储在存储器160(或者其它类型的存储介质)中。
[0056]移动通信模块112将无线电信号发送到基站(例如,接入点、节点B等等)、外部终端以及服务器中的至少一个和/或从其接收无线电信号。这样的无线电信号可以包括语音通话信号、视频通话信号、或者根据文本和/或多媒体消息发送和/或接收的各种类型的数据。
[0057]无线互联网模块113支持移动终端100的无线互联网接入。无线互联网模块113可以内部或外部地耦接到终端。无线互联网模块113所涉及的无线互联网接入技术可以包括无线局域网(WLAN)、无线相容性认证(W1-Fi )、无线宽带(Wibro)、全球微波互联接入(Wimax)、高速下行链路分组接入(HSDPA)等等。
[0058]短程通信模块114是用于支持短程通信的模块。短程通信技术的一些示例包括蓝牙?、射频识别(RFID)、红外数据协会(IrDA)、超宽带(UWB)、紫蜂?等等。
[0059]位置信息模块115是用于检查或获取移动终端100的位置信息的模块。位置信息模块115的典型示例是全球定位系统(GPS)模块115。根据当前的技术,GPS模块115计算来自三个或更多卫星的距离信息和准确的时间信息并且对于计算的信息应用三角测量法,从而根据经度、玮度和高度准确地计算三维当前位置信息。当前,用于计算位置和时间信息的方法使用三颗卫星并且通过使用另外的一颗卫星校正计算出的位置和时间信息的误差。此外,GPS模块115能够通过实时地连续计算当前位置信息来计算速度信息。
[0060]A/V输入单元120用于接收音频或视频信号。A/V输入单元120可以包括相机121和麦克风122,相机121对在视频捕获模式或图像捕获模式中由图像捕获装置获得的静态图片或视频的图像数据进行处理。处理后的图像帧可以显示在显示单元151上。经相机121处理后的图像帧可以存储在存储器160(或其它存储介质)中或者经由无线通信单元110进行发送,可以根据移动终端100的构造提供两个或更多相机121。麦克风122可以在电话通话模式、记录模式、语音识别模式等等运行模式中经由麦克风接收声音(音频数据),并且能够将这样的声音处理为音频数据。处理后的音频(语音)数据可以在电话通话模式的情况下转换为可经由移动通信模块112发送到移动通信基站的格式输出。麦克风122可以实施各种类型的噪声消除(或抑制)算法以消除(或抑制)在接收和发送音频信号的过程中产生的噪声或者干扰。
[0061]用户输入单元130可以根据用户输入的命令生成键输入数据以控制移动终端100的各种操作。用户输入单元130允许用户输入各种类型的信息,并且可以包括键盘、锅仔片、触摸板(例如,检测由于被接触而导致的电阻、压力、电容等等的变化的触敏组件)、滚轮、摇杆等等。特别地,当触摸板以层的形式叠加在显示单元151上时,可以形成触摸屏。
[0062]接口单元170用作至少一个外部装置与移动终端100连接可以通过的接口。例如,外部装置可以包括有线或无线头戴式耳机端口、外部电源(或电池充电器)端口、有线或无线数据端口、存储卡端口(典型示例是通用串行总线USB端口)、用于连接具有识别模块的装置的端口、音频输入/输出(I/O)端口、视频I/O端口、耳机端口等等。识别模块可以是存储用于验证用户使用移动终端100的各种信息并且可以包括用户识别模块(ΙΠΜ)、客户识别模块(SIM)、通用客户识别模块(USIM)等等。另外,具有识别模块的装置(下面称为“识别装置”)可以采取智能卡的形式,因此,识别装置可以经由端口或其它连接装置与移动终端100连接。
[0063]接口单元170可以用于接收来自外部装置的输入(例如,数据信息、电力等等)并且将接收到的输入传输到移动终端100内的一个或多个元件或者可以用于在移动终端100和外部装置之间传输数据。
[0064]另外,当移动终端100与外部底座连接时,接口单元170可以用作允许通过其将电力从底座提供到移动终端100的路径或者可以用作允许从底座输入的各种命令信号通过其传输到移动终端100的路径。从底座输入的各种命令信号或电力可以用作用于识别移动终端100是否准确地安装在底座上的信号。
[0065]输出单元150被构造为以视觉、音频和/或触觉方式提供输出信号(例如,音频信号、视频信号、警报信号、振动信号等等)。输出单元150可以包括显示单元151、音频输出模块152、警报单元153等等。
[0066]显示单元151可以显示在移动终端100中处理的信息。例如,当移动终端100处于电话通话模式时,显示单元151可以显示与通话或其它通信(例如,文本消息收发、多媒体文件下载等等)相关的用户界面(UI)或图形用户界面(GUI)。当移动终端100处于视频通话模式或者图像捕获模式时,显示单元151可以显示捕获的图像和/或接收的图像、示出视频或图像以及相关功能的UI或GUI等等。
[0067]同时,当显示单元151和触摸板以层的形式彼此叠加以形成触摸屏时,显示单元151可以用作输入装置和输出装置。显示单元151可以包括液晶显示器(LCD)、薄膜晶体管IXD(TFT-1XD)、有机发光二极管(OLED)显示器、柔性显示器、三维(3D)显示器等等中的至少一种。这些显示器中的一些可以被构造为透明状以允许用户从外部观看,这可以称为透明显示器,典型的透明显示器可以例如为TOLED(透明有机发光二极管)显示器等等。根据特定想要的实施方式,移动终端100可以包括两个或更多显示单元(或其它显示装置),例如,移动终端100可以包括外部显示单元(未示出)和内部显示单元(未示出)。触摸屏可用于检测触摸输入压力以及触摸输入位置和触摸输入面积。
[0068]音频输出模块152可以在移动终端100处于呼叫信号接收模式、通话模式、记录模式、语音识别模式、广播接收模式等等模式下时,将无线通信单元110接收的或者在存储器160中存储的音频数据转换音频信号并且输出为声音。而且,音频输出模块152可以提供与移动终端100执行的特定功能相关的音频输出(例如,呼叫信号接收声音、消息接收声音等等)。音频输出模块152可以包括扬声器、蜂鸣器等等。
[0069]警报单元153可以提供输出以将事件的发生通知给移动终端100。典型的事件可以包括呼叫接收、消息接收、键信号输入、触摸输入等等。除了音频或视频输出之外,警报单元153可以以不同的方式提供输出以通知事件的发生。例如,警报单元153可以以振动的形式提供输出,当接收到呼叫、消息或一些其它进入通信(incoming communicat1n)时,警报单元153可以提供触觉输出(S卩,振动)以将其通知给用户。通过提供这样的触觉输出,即使在用户的移动电话处于用户的口袋中时,用户也能够识别出各种事件的发生。警报单元153也可以经由显示单元151或音频输出模块152提供通知事件的发生的输出。
[0070]存储器160可以存储由控制器180执行的处理和控制操作的软件程序等等,或者可以暂时地存储已经输出或将要输出的数据(例如,电话簿、消息、静态图像、视频等等)。而且,存储器160可以存储关于当触摸施加到触摸屏时输出的各种方式的振动和音频信号的数据。
[0071]存储器160可以包括至少一种类型的存储介质,所述存储介质包括闪存、硬盘、多媒体卡、卡型存储器(例如,SD或DX存储器等等)、随机访问存储器(RAM)、静态随机访问存储器(SRAM)、只读存储器(R0M)、电可擦除可编程只读存储器(EEPROM)、可编程只读存储器(PROM)、磁性存储器、磁盘、光盘等等。而且,移动终端100可以与通过网络连接执行存储器160的存储功能的网络存储装置协作。
[0072]控制器180通常控制移动终端100的总体操作。例如,控制器180执行与语音通话、数据通信、视频通话等等相关的控制和处理。另外,控制器180可以包括用于再现或回放多媒体数据的多媒体模块181,多媒体模块181可以构造在控制器180内,或者可以构造为与控制器180分离。控制器180可以执行模式识别处理,以将在触摸屏上执行的手写输入或者图片绘制输入识别为字符或图像。
[0073]电源单元190在控制器180的控制下接收外部电力或内部电力并且提供操作各元件和组件所需的适当的电力。
[0074]这里描述的各种实施方式可以以使用例如计算机软件、硬件或其任何组合的计算机可读介质来实施。对于硬件实施,这里描述的实施方式可以通过使用特定用途集成电路(ASIC)、数字信号处理器(DSP)、数字信号处理装置(DSPD)、可编程逻辑装置(PLD)、现场可编程门阵列(FPGA)、处理器、控制器、微控制器、微处理器、被设计为执行这里描述的功能的电子单元中的至少一种来实施,在一些情况下,这样的实施方式可以在控制器180中实施。对于软件实施,诸如过程或功能的实施方式可以与允许执行至少一种功能或操作的单独的软件模块来实施。软件代码可以由以任何适当的编程语言编写的软件应用程序(或程序)来实施,软件代码可以存储在存储器160中并且由控制器180执行。
[0075]至此,已经按照其功能描述了移动终端100。下面,为了简要起见,将描述诸如折叠型、直板型、摆动型、滑动型移动终端100等等的各种类型的移动终端100中的滑动型移动终端100作为示例。因此,本发明能够应用于任何类型的移动终端100,并且不限于滑动型移动终端100。
[0076]如图1中所示的移动终端100可以被构造为利用经由帧或分组发送数据的诸如有线和无线通信系统以及基于卫星的通信系统来操作。
[0077]现在将参考图2描述其中根据本发明的移动终端100能够操作的通信系统。
[0078]这样的通信系统可以使用不同的空中接口和/或物理层。例如,由通信系统使用的空中接口包括例如频分多址(FDMA)、时分多址(TDMA)、码分多址(CDMA)和通用移动通信系统(UMTS)(特别地,长期演进(LTE))、全球移动通信系统(GSM)等等。作为非限制性示例,下面的描述涉及CDMA通信系统,但是这样的教导同样适用于其它类型的系统。
[0079]参考图2,⑶MA无线通信系统可以包括多个移动终端100、多个基站(BS)270、基站控制器(BSC)275和移动交换中心(MSCWSOJSC 280被构造为与公共电话交换网络(PSTN)290形成接口。MSC 280还被构造为与可以经由回程线路耦接到基站270的BSC 275形成接口。回程线路可以根据若干己知的接口中的任一种来构造,所述接口包括例如El/Tl、ATM、IP、PPP、帧中继、HDSL、ADSL或xDSL。将理解的是,如图2中所示的系统可以包括多个BSC2750。
[0080]每个BS270可以服务一个或多个分区(或区域),由多向天线或指向特定方向的天线覆盖的每个分区放射状地远离BS 270。或者,每个分区可以由用于分集接收的两个或更多天线覆盖。每个BS 270可以被构造为支持多个频率分配,并且每个频率分配具有特定频谱(例如,1.25MHz,5MHz等等)。
[0081]分区与频率分配的交叉可以被称为CDMA信道。BS270也可以被称为基站收发器子系统(BTS)或者其它等效术语。在这样的情况下,术语“基站”可以用于笼统地表示单个BSC275和至少一个BS 270。基站也可以被称为“蜂窝站”。或者,特定BS 270的各分区可以被称为多个蜂窝站。
[0082]如图2中所示,广播发射器(BT)295将广播信号发送给在系统内操作的移动终端100。如图1中所示的广播接收模块111被设置在移动终端100处以接收由BT295发送的广播信号。在图2中,示出了几个卫星300,例如可以采用全球定位系统(GPS)卫星300。卫星300帮助定位多个移动终端100中的至少一个。
[0083]在图2中,描绘了多个卫星300,但是理解的是,可以利用任何数目的卫星获得有用的定位信息。如图1中所示的GPS模块115通常被构造为与卫星300配合以获得想要的定位信息。替代GPS跟踪技术或者在GPS跟踪技术之外,可以使用可以跟踪移动终端100的位置的其它技术。另外,至少一个GPS卫星300可以选择性地或者额外地处理卫星DMB传输。
[0084]作为无线通信系统的一个典型操作,BS270接收来自各种移动终端100的反向链路信号。移动终端100通常参与通话、消息收发和其它类型的通信。特定基站270接收的每个反向链路信号被在特定BS 270内进行处理。获得的数据被转发给相关的BSC 275ASC提供通话资源分配和包括BS 270之间的软切换过程的协调的移动管理功能。BSC275还将接收到的数据路由到MSC 280,其提供用于与PSTN 290形成接口的额外的路由服务。类似地,PSTN290与MSC280形成接口,MSC与BSC 275形成接口,并且BSC 275相应地控制BS 270以将正向链路信号发送到移动终端100。
[0085]移动终端中无线通信单元110的移动通信模块112基于移动终端内置的接入移动通信网络(如2G/3G/4G等移动通信网络)的必要数据(包括用户识别信息和鉴权信息)接入移动通信网络为移动终端用户的网页浏览、网络多媒体播放等业务传输移动通信数据(包括上行的移动通信数据和下行的移动通信数据)。
[0086]无线通信单元110的无线互联网模块113通过运行无线热点的相关协议功能而实现无线热点的功能,无线热点支持多个移动终端(移动终端之外的任意移动终端)接入,通过复用移动通信模块112与移动通信网络之间的移动通信连接为移动终端用户的网页浏览、网络多媒体播放等业务传输移动通信数据(包括上行的移动通信数据和下行的移动通信数据),由于移动终端实质上是复用移动终端与通信网络之间的移动通信连接传输移动通信数据的,因此移动终端消耗的移动通信数据的流量由通信网络侧的计费实体计入移动终端的通信资费,从而消耗移动终端签约使用的通信资费中包括的移动通信数据的数据流量。
[0087]如图3所示,本实施例提供一种信息处理方法,包括:
[0088]步骤SI10:解析日志中的日志信息,提取事件信息;
[0089]步骤S120:封装所述事件信息形成操作事件;其中,所述操作事件用于触发应用组件执行对应的操作;
[0090]步骤S130:利用应用组件响应所述操作事件,以重现故障场景和程序运行状态。
[0091]本实施例中所述信息处理方法,可应用于各种程序调试的应用场景。当一个应用程序拷贝到电子设备中运行以后,可能会出现各种故障。这些故障都会被日志以日志信息的方式记录下来。
[0092]在本实施例中电子设备会自动解析日志中的日志信息,提取出事件信息。这里的事件信息可为应用程序在操作过程中产生的各种事件,例如,启动应用程序的启动事件、触摸屏接收到滑动的滑动事件及驱动一个应用程序执行一个特殊操作的驱动事件等各种操作事件。
[0093]在步骤S120中,会根据提取的事件信息封装成电子设备底层可识别的操作事件。例如,利用事件函数,将事件信息封装成操作事件。且该操作事件与日志信息所记录的历史事件的区别点,仅在于触发应用组件执行操作的触发时间不同。例如,所述事件信息是发生与昨天滑动操作对应的滑动事件A;当前时间利用从日志信息中提取的滑动事件A的事件信息,封装成了滑动事件B;滑动事件B与滑动事件A的差异仅在于滑动事件A是昨天已经发生过的历史时间,而滑动事件B是将要注入分发组件,由分发组件分发到响应组件,待响应的滑动事件。在步骤S130中,将所述操作事件分发到各个应用组件,这些应用组件就会重现响应历史事件时的场景和程序运行状态。若某一个事件是导致运行故障的事件,则电子设备会再次出现运行故障,显然此时就方便调试人员根据电子设备的再次运行,简便定位出故障和故障时的程序运行状态。这样程序调试的效率大大提升了,对调试人员的素质要求大大降低了,降低了调试成本和调试时间。
[0094]进一步地,
[0095]所述方法还包括:
[0096]依据所述日志信息的输出格式,配置解析规则;
[0097]所述步骤SI 20可包括:
[0098]利用所述解析规则,提取所述事件信息。
[0099]日志中每一条日志都有对应输出格式,该输出格式确定了日志信息中哪些字段对应了哪些内容。这样为了方便调试,可以事先配置解析规则,利用该解析规则,从而日志信息中提取出重现故障的事件信息。
[0100]图4所示的为日志中多条日志的显示效果图。在图4中所示的日志信息中显示有事件发生的时间、事件类型、时间对应的窗口、指针位置及操作参数等。而这些日志信息都有预定的输出格式,这样就方便根据日志信息的输出格式,从预定位置提取出所需的事件信息。
[0101]进一步地,所述步骤S120具体可包括:利用正则表达式,从所述日志信息中提取事件信息。
[0102]以下提供一条日志信息:
[0103]Line 4103:04-04 10:39:38.316ff/ViewRootImpl(3172):Cancelling event dueto no window focus:KeyEvent{act1n = ACT10N_UP,keyCode = KEYC0DE_BACK,scanCode=158 ,metaState = 0,flags = 0x68 ,repeatCount = 0,eventTime = 184563 ,downTime =184480,deviceld = 10, source = 0x101}。
[0104]以下为一个正则表达式的示例:
[0105].*?: (?〈time>.*? ).*?...*?: (?〈eventType>.*?) {(?<eventInf o>.*)}。
[0106]利用该正则表达式:将提取出04-04 10:39:38.316、KeyEvent 及 act1n=ACT10N_UP,keyCode = KEYC0DE_BACK,scanCode = 158,metaState = O, flags = 0x68,repeatCount =O, eventTime = 184563 ,downTime = 184480 ,deviceld = 10, source = 0x101。
[0107]所述04-04 10:39:38.316,为历史事件的发生时间;所述KeyEvent为键盘事件是一种事件类型;所述act 1n = ACT10N_UP , keyCode = KEYC0DE_BACK , scanCode = 158 ,metaState = 0,flags = 0x68 ,repeatCount = 0 ,eventTime = 184563 ,downTime = 184480,deviceld = 10, source = 0x101 为事件的参数信息。
[0108]所述〈time〉、〈eventType〉及〈event Inf o>为提取出来的各个事件参数的命名分组命名;例如04-04 10:39:38.316属于time这一个命名分组。通过在正则表达式中增加命名分组,方便电子设备标识提取的不同的事件信息,以方便调试人员查阅,增加了信息的可辨识度。
[0109]在具体的实现过程中,上述正则表达式还可改写为
K?.*)},改写后的正则表达式也可以实现上述发生时间、事件类型及参数信息的提取,但是信息提取之后,电子设备不会利用time、evenType及eventlnfo来标识对应的事件信息。
[0110]所述步骤SllO可包括:提取历史事件的发生时间、事件类型和操作参数。所述步骤S120可包括:根据所述发生时间,确定所述操作事件的操作时序;所述操作时序包括各个操作发生的先后顺序及相邻两个所述操作间的时间间隔;依据所述操作时序及所述事件类型构建及所述操作参数,构建所述操作事件。一个电子设备可运行有多个应用,具体哪个应用有故障,可以通过分析日志信息来确定,也可以通过上述正则表达式来提取。一个操作事件可导致一个或多个操作,则这些操作在响应历史事件时都是有一定的时间顺序的,在本实施例中通过提取所述发生时间,确定各个操作的时间先后顺序,以及相邻两个操作之间的时间间隔;所述时间顺序及所述时间间隔组成了所述时序,根据所述时序、时间类型及作用的应用,封装出可注入到分发组件的操作事件。分发组件再分发给对应响应组件,由响应组件执行对应的操作,响应所述操作事件,从而重现历史事件的事件场景和运行状态。若日志信息中包括导致设备故障的日志,就能够实现故障场景和故障场景对应的运行状态的重现。
[0111]所述方法还包括:
[0112]启动调试应用的应用界面;
[0113]检测应用于所述应用界面的操作指示;
[0114]所述步骤SI 10包括:
[0115]当所述操作指示进行程序调试时,所述调试应用读取并解析所述日志信息,以提取所述事件ig息。
[0116]在本实施例中可以在电子设备中安装专用的调试应用,在启动调试应用之后,电子设备会显示调试应用界面,该调试应用界面可用于调试工作人员控制调试过程,例如,开始利用日志信息的启动调试过程,中止或终止调试过程等。在本实施例将接收操作指示进行程序调试时,该调试应用会读取并解析所述日志程序,开始程序的调试。
[0117]这样就调试应用和应用界面都属于程序框架中的上层框架,这样就通过上层框架构建了,触发底层框架中响应组件再次响应已响应过历史事件的操作事件,可以实现故障场景重现或故常场景的运行状态的重现。
[0118]如图5所不,本实施例提供一种电子设备,包括:
[0119]解析单元310,用于解析日志中的日志信息,提取事件信息;
[0120]封装单元320,用于封装所述事件信息形成操作事件;其中,所述操作事件用于触发应用组件执行对应的操作;
[0121 ]响应单元330,用于利用应用组件响应所述操作事件,以重现故障场景和程序运行状态。
[0122]本实施例所提供的电子设备可为手机、平板电脑、可穿戴式设备等各种电子设备,例如可如图1所示的终端设备。
[0123]本实施例提供的解析单元310、封装单元320及响应单元330都可对应于图1中的控制器等结构。所述控制器可为中央处理器、微处理器、数字信号处理器、可编程阵列或专用集成电路等。
[0124]本实施例所述的电子设备,能够通过解析日志信息,提取出历史事件的事件信息,从而确定出已响应过的历史事件,在由所述封装单元,封装构造出操作事件,相当于是响应组件再次响应所述历史事件,实现历史场景和历史程序状态的重新,如历史事件是导致故障的事件,则会重现故障场景和故障场景对应的程序状态,这样就实现了程序调试过程中对故障的定位。
[0125]进一步地,所述电子设备还包括:
[0126]配置单元,用于依据所述日志信息的输出格式,配置解析规则;
[0127]所述解析单元310,用于利用所述解析规则,提取所述事件信息。
[0128]在本实施例中所述方法还包括配置单元,可用于配置解析规则,具体可对应于存储介质,可存储所述解析规则。所述存储介质可为只读存储器R0M、随机存储器RAM或闪存flash等各种存储介质,可选为非瞬间存储介质。
[0129]进一步地,所述解析单元310,具体用于正则表达式解析所述日志信息。此处的所述正则表达式即为所述解析规则。利用正则表达式提取日志信息,具有信息提取简单的特点。
[0130]在一些实施例中,所述解析单元310,具体用于提取历史事件的发生时间、事件类型和操作参数;所述封装单元320,具体用于根据所述发生时间,确定所述操作事件的操作时序;所述操作时序包括各个操作发生的先后顺序及相邻两个所述操作间的时间间隔;依据所述操作时序及所述事件类型构建及所述操作参数,构建所述操作事件。
[0131]在另一些实施例中,所述电子设备还包括:启动单元,用于启动调试应用的应用界面;检测单元,用于检测应用于所述应用界面的操作指示;所述解析单元310,用于当所述操作指示进行程序调试时,所述调试应用读取并解析所述日志信息,以提取所述事件信息。本实施例中所述启动单元可对应于图1中所述控制器等结构等。所述检测单元可对应于各种人机交互接口,例如、触摸屏或键盘或鼠标或语音识别结构等,能够检测出操作指示。所述解析单元310在调试人员的操作指示下,解析日志信息;增强了调试人员对设备的控制力度。
[0132]以下结合上述任意实施例提供几个具体示例:
[0133]示例一:
[0134]如图6所示,本示例提供一种信息处理方法,包括:
[0135]配置解析规则;
[0136]记载日志;
[0137]利用解析规则解析日志,获得事件信息;
[0138]封装事件信息;分装后的事件信息即为所述操作事件。
[0139]将封装后的事件信息,注入到移动终端中,移动终端将响应所述操作事件,重现各种事件场景。
[0140]示例二:
[0141]如图7所示,本示例提供一种信息处理方法,包括:预处理操作和故障定位操作两部分。
[0142]所述预处理操作包括:配置规则,这里的配置规则为前述的解析规则,例如,所述正则表达式。
[0143]所述故障定位操作包括:加载日志、读取规则、提取信息、封装注入及响应注入。
[0144]这里的加载日志,为读取各种日志,获取日志信息。
[0145]所述读取规则,即为读取所述解析规则。
[0146]所述提取信息,为利用解析规则解析日志信息,提取事件信息。
[0147]所述封装注入,为将提取的事件信息封装成操作事件,并发送给移动终端的分发组件。这里的分发组件可对应于inputDispatcher这一个类。
[0148]所述响应注入,为响应组件执行对应的操作,响应所述操作事件。
[0149]示例三:
[0150]如图8所示为通常的操作事件(图中以驱动事件为例)传递到分发组件(inputDispatcher),需要经过输入事件目录(dev/input/),再由读取组件(inputReader)从所述输入事件目录中读取驱动事件,再注入到分发组件中。分发组件分发给各个页面管理组件(ViewRootlmpl)中。若利用本实施例提供的信息处理方法,事件由上层框架直接注入分发组件中。这里的事件为操作时间的简写。
[0151]在图8中还显示有页面组件1、页面组件2……及页面组件N。在图8中页面组件I响应,并进行对应操作之后,传递给活动组件(Activity),活动组件将操作执行后的信息传递给视图组件(View)视图组件触发触摸跟踪组件(VelocityTracker)执行滑动速度计算,并进一步由速率曲线组件(OverScroller),利用滑动算法生成滑动路径。所述视图配置组件(ViewConf igurat1n)进行滑动操作的摩擦力、重力及速度限制等配置。所述编排组件(choreography)用于进行注册回调或回调及事件折叠。
[0152]显然通过比对可知,本实施例中所述分发组件获取事件的途径,从读取组件获得,改变到上层框架。上层框架是通过解析日志,封装形成了分发组件可识别的操作事件。
[0153]图8所示的各个组件组成了输入子系统,是所有1/0设备驱动的中间层,输入设备会自动分配输入节点。滑动触摸屏之后,驱动会将信息上报给内核的输入子系统。例如安卓Android系统的输入管理器会开启一个线程通过事件集线器EventHub不停地从/dev/input/目录下面的设备文件读取事件,然后通过InputDispatcher分发给连接到客户端。
[0154]具体的操作可步骤:
[0155]1、依据日志格式,录入解析规则;
[0156]2、程序载入日志,依据规则将日志文件中的点击、触摸等操作产生的事件按时间发生的顺序依次解析;
[0157]3、将解析的操作封装为移动终端可以识别的事件注入移动终端。
[0158]本方案依托上层框架事件触发的机制,并根据格式自动进行对其进行解析,提取出事件信息,对其进行封装,并自动注入移动终端,移动终端可以很直观的复现测试人员或用户当时的操作和程序的运行状态。这样,庞大的日志文件由程序自动执行注入,准确快速的复现场景,为开发人员定位问题点提供参考信息。
[0159]在本申请所提供的几个实施例中,应该理解到,所揭露的设备和方法,可以通过其它的方式实现。以上所描述的设备实施例仅仅是示意性的,例如,所述单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,如:多个单元或组件可以结合,或可以集成到另一个系统,或一些特征可以忽略,或不执行。另外,所显示或讨论的各组成部分相互之间的耦合、或直接耦合、或通信连接可以是通过一些接口,设备或单元的间接耦合或通信连接,可以是电性的、机械的或其它形式的。
[0160]上述作为分离部件说明的单元可以是、或也可以不是物理上分开的,作为单元显示的部件可以是、或也可以不是物理单元,即可以位于一个地方,也可以分布到多个网络单元上;可以根据实际的需要选择其中的部分或全部单元来实现本实施例方案的目的。
[0161]另外,在本发明各实施例中的各功能单元可以全部集成在一个处理模块中,也可以是各单元分别单独作为一个单元,也可以两个或两个以上单元集成在一个单元中;上述集成的单元既可以采用硬件的形式实现,也可以采用硬件加软件功能单元的形式实现。
[0162]本领域普通技术人员可以理解:实现上述方法实施例的全部或部分步骤可以通过程序指令相关的硬件来完成,前述的程序可以存储于一计算机可读取存储介质中,该程序在执行时,执行包括上述方法实施例的步骤;而前述的存储介质包括:移动存储设备、只读存储器(R0M,Read_0nly Memory)、随机存取存储器(RAM ,Random Access Memory)、磁碟或者光盘等各种可以存储程序代码的介质。
[0163]以上所述,仅为本发明的【具体实施方式】,但本发明的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本发明揭露的技术范围内,可轻易想到变化或替换,都应涵盖在本发明的保护范围之内。因此,本发明的保护范围应以所述权利要求的保护范围为准。
【主权项】
1.一种信息处理方法,其特征在于,包括: 解析日志中的日志信息,提取事件信息; 封装所述事件信息形成操作事件;其中,所述操作事件用于触发应用组件执行对应的操作; 利用应用组件响应所述操作事件,以重现故障场景和程序运行状态。2.根据权利要求1所述的方法,其特征在于, 所述方法还包括: 依据所述日志信息的输出格式,配置解析规则; 所述解析日志中的日志信息,提取事件信息,包括: 利用所述解析规则,提取所述事件信息。3.根据权利要求2所述的方法,其特征在于, 所述利用所述解析规则,提取所述事件信息,包括: 利用正则表达式,从所述日志信息中提取所述事件信息。4.根据权利要求1、2或3所述的方法,其特征在于, 所述解析日志中的日志信息,提取事件信息,包括: 提取历史事件的发生时间、事件类型和操作参数; 所述封装所述事件信息形成操作事件,包括: 根据所述发生时间,确定所述操作事件的操作时序;所述操作时序包括各个操作发生的先后顺序及相邻两个所述操作间的时间间隔; 依据所述操作时序及所述事件类型构建及所述操作参数,构建所述操作事件。5.根据权利要求1、2或3所述的方法,其特征在于, 所述方法还包括: 启动调试应用的应用界面; 检测应用于所述应用界面的操作指示; 所述解析日志中的日志信息,提取事件信息,包括: 当所述操作指示进行程序调试时,所述调试应用读取并解析所述日志信息,以提取所述事件信息。6.一种电子设备,其特征在于,包括: 解析单元,用于解析日志中的日志信息,提取事件信息; 封装单元,用于封装所述事件信息形成操作事件;其中,所述操作事件用于触发应用组件执行对应的操作; 响应单元,用于利用应用组件响应所述操作事件,以重现故障场景和程序运行状态。7.根据权利要求6所述的电子设备,其特征在于, 所述电子设备还包括: 配置单元,用于依据所述日志信息的输出格式,配置解析规则; 所述解析单元,用于利用所述解析规则,提取所述事件信息。8.根据权利要求7所述的电子设备,其特征在于, 所述解析单元,具体用于利用正则表达式,从所述日志信息中提取所述事件信息。9.根据权利要求6、7或8所述的电子设备,其特征在于, 所述解析单元,具体用于提取历史事件的发生时间、事件类型和操作参数; 所述封装单元,具体用于根据所述发生时间,确定所述操作事件的操作时序;所述操作时序包括各个操作发生的先后顺序及相邻两个所述操作间的时间间隔;依据所述操作时序及所述事件类型构建及所述操作参数,构建所述操作事件。10.根据权利要求6、7或8所述的电子设备,其特征在于, 所述电子设备还包括: 启动单元,用于启动调试应用的应用界面; 检测单元,用于检测应用于所述应用界面的操作指示; 所述解析单元,用于当所述操作指示进行程序调试时,所述调试应用读取并解析所述日志信息,以提取所述事件信息。
【文档编号】G06F11/34GK106055451SQ201610345210
【公开日】2016年10月26日
【申请日】2016年5月23日
【发明人】安占磊
【申请人】努比亚技术有限公司
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1