CN111367799B - 定位源代码崩溃位置的方法、装置、介质及电子设备 - Google Patents
定位源代码崩溃位置的方法、装置、介质及电子设备 Download PDFInfo
- Publication number
- CN111367799B CN111367799B CN202010131329.7A CN202010131329A CN111367799B CN 111367799 B CN111367799 B CN 111367799B CN 202010131329 A CN202010131329 A CN 202010131329A CN 111367799 B CN111367799 B CN 111367799B
- Authority
- CN
- China
- Prior art keywords
- crash
- virtualized
- processing unit
- source code
- central processing
- 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
- 238000000034 method Methods 0.000 title claims abstract description 98
- 230000015556 catabolic process Effects 0.000 title claims description 9
- 238000012545 processing Methods 0.000 claims abstract description 204
- 238000004088 simulation Methods 0.000 claims abstract description 25
- 230000006870 function Effects 0.000 claims description 156
- 230000008569 process Effects 0.000 claims description 20
- 238000004590 computer program Methods 0.000 claims description 18
- 238000010586 diagram Methods 0.000 description 30
- 238000004891 communication Methods 0.000 description 10
- 230000003287 optical effect Effects 0.000 description 8
- 230000009471 action Effects 0.000 description 4
- 230000005540 biological transmission Effects 0.000 description 4
- 238000005516 engineering process Methods 0.000 description 4
- 230000000644 propagated effect Effects 0.000 description 4
- 230000011218 segmentation Effects 0.000 description 4
- 239000004065 semiconductor Substances 0.000 description 4
- 239000000835 fiber Substances 0.000 description 3
- 230000005856 abnormality Effects 0.000 description 2
- 230000000903 blocking effect Effects 0.000 description 2
- 238000011161 development Methods 0.000 description 2
- 230000018109 developmental process Effects 0.000 description 2
- 230000003993 interaction Effects 0.000 description 2
- 239000004973 liquid crystal related substance Substances 0.000 description 2
- 239000013307 optical fiber Substances 0.000 description 2
- 238000004806 packaging method and process Methods 0.000 description 2
- 230000002787 reinforcement Effects 0.000 description 2
- 230000009131 signaling function Effects 0.000 description 2
- 239000000758 substrate Substances 0.000 description 2
- 230000006978 adaptation Effects 0.000 description 1
- 230000009286 beneficial effect Effects 0.000 description 1
- 230000002708 enhancing effect Effects 0.000 description 1
- 238000004519 manufacturing process Methods 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 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/36—Preventing errors by testing or debugging software
- G06F11/3604—Software analysis for verifying properties of programs
- G06F11/3608—Software analysis for verifying properties of programs using formal methods, e.g. model checking, abstract interpretation
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/36—Preventing errors by testing or debugging software
- G06F11/362—Software debugging
- G06F11/366—Software debugging using diagnostics
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/36—Preventing errors by testing or debugging software
- G06F11/3664—Environments for testing or debugging software
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/44—Arrangements for executing specific programs
- G06F9/455—Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
- G06F9/45533—Hypervisors; Virtual machine monitors
- G06F9/45558—Hypervisor-specific management and integration aspects
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/44—Arrangements for executing specific programs
- G06F9/455—Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
- G06F9/45533—Hypervisors; Virtual machine monitors
- G06F9/45558—Hypervisor-specific management and integration aspects
- G06F2009/45583—Memory management, e.g. access or allocation
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Software Systems (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Computer Hardware Design (AREA)
- Quality & Reliability (AREA)
- Debugging And Monitoring (AREA)
Abstract
本发明提供了一种定位源代码崩溃位置的方法,该方法可以应用于服务器或终端,其中,应用于服务器的方法包括:接收由终端的应用程序发送的第一崩溃日志,所述第一崩溃日志中包含模拟中央处理器的运行环境信息,根据所述模拟中央处理器的运行环境信息定位第一源代码的崩溃位置,通过该方式可以准确定位到第一源代码的崩溃位置,从而提升了工作效率。本发明还提供了一种定位源代码崩溃位置的装置、介质以及电子设备。
Description
技术领域
本发明涉及数据处理的技术领域,具体而言,涉及一种定位源代码崩溃位置的方法、装置、介质及电子设备。
背景技术
随着移动平台应用加固技术的发展,新一代虚拟加固,即NATIVE层代码虚拟化技术已经逐渐开始应用。该种技术的大致流程为抽取原指令、重写重定位、重新编译再通过虚拟指令解释器执行,所以在运行虚拟化后的代码时若发生崩溃,常规的崩溃定位方法只能定位到当前运行环境,即解释器代码的崩溃栈、崩溃时寄存器等信息,而无法定位源代码的崩溃位置。
需要说明的是,在上述背景技术部分公开的信息仅用于加强对本发明的背景的理解,因此可以包括不构成对本领域普通技术人员已知的现有技术的信息。
发明内容
本发明实施例的目的在于提供一种定位源代码崩溃位置的方法、装置、介质及电子设备,进而至少可以在一定程度上实现定位源代码的崩溃位置。
本发明的其他特性和优点将通过下面的详细描述变得显然,或部分地通过本发明的实践而习得。
根据本发明实施例的第一方面,提供了一种定位源代码崩溃位置的方法,应用于服务器,包括:接收由终端的应用程序发送的第一崩溃日志,所述第一崩溃日志中包含模拟中央处理器的运行环境信息;根据所述模拟中央处理器的运行环境信息定位第一源代码的崩溃位置。
在本发明的一些实施例中,所述模拟中央处理器的运行环境信息包括以下任意一项或多项:虚拟化线程信息、虚拟化函数调用栈、虚拟化寄存器信息、虚拟化堆栈内存信息。
在本发明的一些实施例中,根据所述模拟中央处理器的运行环境信息定位所述第一源代码的崩溃位置包括:根据所述模拟中央处理器的虚拟化函数调用栈、虚拟化线程信息和虚拟化寄存器中的程序计数器信息定位所述第一源代码的崩溃位置。
在本发明的一些实施例中,该方法还包括:接收由所述终端的应用程序发送的第二崩溃日志,所述第二崩溃日志中包含真实中央处理器的运行环境信息;根据所述真实中央处理器的运行环境信息定位第二源代码的崩溃位置。
根据本发明实施例的第二方面,提供了一种定位源代码崩溃位置的方法,应用于终端,包括:获取第一特定信号,所述第一特定信号包括在运行与应用程序相关的虚拟化后的代码过程中出现崩溃时产生的信号;根据所述第一特定信号调用第一信号处理函数;利用所述第一信号处理函数采集模拟中央处理器的运行环境信息;基于所述模拟中央处理器的运行环境信息生成第一崩溃日志;在所述应用程序下次启动时,向服务器发送所述第一崩溃日志,以使得所述服务器根据所述第一崩溃日志定位第一源代码的崩溃位置。
在本发明的一些实施例中,所述模拟中央处理器的运行环境信息包括以下任意一项或多项:虚拟化线程信息、虚拟化函数调用栈、虚拟化寄存器信息、虚拟化堆栈内存信息。
在本发明的一些实施例中,该方法还包括:获取第二特定信号,所述第二特定信号包括在运行与所述应用程序相关的非虚拟化后的代码过程中出现崩溃时产生的信号;根据所述第二特定信号调用第二信号处理函数;利用所述第二信号处理函数采集真实中央处理器的运行环境信息;基于所述真实中央处理器的运行环境信息生成第二崩溃日志;在所述应用程序下次启动时,向所述服务器发送所述第二崩溃日志,以使得所述服务器根据所述第二崩溃日志定位所述第二源代码的崩溃位置。
在本发明的一些实施例中,该方法还包括:在生成所述第一崩溃日志之后,将所述第一信号处理函数更新为终端系统的信号处理函数;根据所述终端系统的信号处理函数退出所述应用程序。
在本发明的一些实施例中,该方法还包括:在生成所述第二崩溃日志之后,将所述第二信号处理函数更新为终端系统的信号处理函数;根据所述终端系统的信号处理函数退出所述应用程序。
根据本发明实施例的第三方面,提供了一种定位源代码崩溃位置的装置,应用于服务器,包括:第一接收模块,用于接收由终端的应用程序发送的第一崩溃日志,所述第一崩溃日志中包含模拟中央处理器的运行环境信息;第一定位模块,用于根据所述模拟中央处理器的运行环境信息定位第一源代码的崩溃位置。
在本发明的一些实施例中,所述模拟中央处理器的运行环境信息包括以下任意一项或多项:虚拟化线程信息、虚拟化函数调用栈、虚拟化寄存器信息、虚拟化堆栈内存信息。
在本发明的一些实施例中,上述第一定位模块被配置为:根据所述模拟中央处理器的虚拟化函数调用栈、虚拟化线程信息和虚拟化寄存器中的程序计数器信息定位所述第一源代码的崩溃位置。
在本发明的一些实施例中,该装置还包括:第二接收模块,用于接收由所述终端的应用程序发送的第二崩溃日志,所述第二崩溃日志中包含真实中央处理器的运行环境信息;第二定位模块,用于根据所述真实中央处理器的运行环境信息定位第二源代码的崩溃位置。
根据本发明实施例的第四方面,一种定位源代码崩溃位置的装置,应用于终端,包括:第一获取模块,用于获取第一特定信号,所述第一特定信号包括在运行与应用程序相关的虚拟化后的代码过程中出现崩溃时产生的信号;第一调用模块,用于根据所述第一特定信号调用第一信号处理函数;第一采集模块,利用所述第一信号处理函数采集模拟中央处理器的运行环境信息;第一生成模块,基于所述模拟中央处理器的运行环境信息生成第一崩溃日志;第一发送模块,在所述应用程序下次启动时,向服务器发送所述第一崩溃日志,以使得所述服务器根据所述第一崩溃日志定位第一源代码的崩溃位置。
在本发明的一些实施例中,所述模拟中央处理器的运行环境信息包括以下任意一项或多项:虚拟化线程信息、虚拟化函数调用栈、虚拟化寄存器信息、虚拟化堆栈内存信息。
在本发明的一些实施例中,该装置还包括:第二获取模块,用于获取第二特定信号,所述第二特定信号包括在运行与所述应用程序相关的非虚拟化后的代码过程中出现崩溃时产生的信号;第二调用模块,用于根据所述第二特定信号调用第二信号处理函数;第二采集模块,利用所述第二信号处理函数采集真实中央处理器的运行环境信息;第二生成模块,基于所述真实中央处理器的运行环境信息生成第二崩溃日志;第二发送模块,在所述应用程序下次启动时,向所述服务器发送所述第二崩溃日志,以使得所述服务器根据所述第二崩溃日志定位所述第二源代码的崩溃位置。
在本发明的一些实施例中,该装置还包括:第一更新模块,在生成所述第一崩溃日志之后,将所述第一信号处理函数更新为终端系统的信号处理函数;第一退出模块,用于根据所述终端系统的信号处理函数退出所述应用程序。
在本发明的一些实施例中,该装置还包括:第二更新模块,在生成所述第二崩溃日志之后,将所述第二信号处理函数更新为终端系统的信号处理函数;第二退出模块,用于根据所述终端系统的信号处理函数退出所述应用程序。
根据本发明实施例的第五方面,提供了一种电子设备,包括:一个或多个处理器;存储装置,用于存储一个或多个程序,当所述一个或多个程序被所述一个或多个处理器执行时,使得所述一个或多个处理器实现如上述实施例中第一方面或第二方面所述的定位源代码崩溃位置的方法。
根据本发明实施例的第六方面,提供了一种计算机可读介质,其上存储有计算机程序,所述程序被处理器执行时实现如上述实施例中第一方面或第二方面所述的定位源代码崩溃位置的方法。
本发明实施例提供的技术方案可以包括以下有益效果:
在本发明的一些实施例所提供的技术方案中,接收由终端的应用程序发送的第一崩溃日志,所述第一崩溃日志中包含模拟中央处理器的运行环境信息,然后根据该模拟中央处理器的运行环境信息定位第一源代码的崩溃位置,通过该方式可以准确定位到第一源代码的崩溃位置,从而提升了工作效率。
应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本发明。
附图说明
此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本发明的实施例,并与说明书一起用于解释本发明的原理。显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。在附图中:
图1示出了可以应用本发明实施例的定位源代码崩溃位置的方法或定位源代码崩溃位置的装置的示例性系统架构的示意图;
图2示意性示出了根据本发明的实施例的应用于服务器的定位源代码崩溃位置的方法的流程图;
图3示意性示出了根据本发明的另一个实施例的应用于服务器的定位源代码崩溃位置的方法的流程图;
图4示意性示出了根据本发明的实施例的应用于终端的定位源代码崩溃位置的方法的流程图;
图5示意性示出了根据本发明的另一个实施例的应用于终端的定位源代码崩溃位置的方法的流程图;
图6示意性示出了根据本发明的另一个实施例的应用于终端的定位源代码崩溃位置的方法的流程图;
图7示意性示出了根据本发明的另一个实施例的应用于终端的定位源代码崩溃位置的方法的流程图;
图8示意性示出了根据本发明的实施例的终端与服务器交互的示意图;
图9示意性示出了根据本发明的实施例的应用于服务器的定位源代码崩溃位置的装置的方框图;
图10示意性示出了根据本发明的另一个实施例的应用于服务器的定位源代码崩溃位置的装置的方框图;
图11示意性示出了根据本发明的实施例的应用于终端的定位源代码崩溃位置的装置的方框图;
图12示意性示出了根据本发明的另一个实施例的应用于终端的定位源代码崩溃位置的装置的方框图;
图13示意性示出了根据本发明的另一个实施例的应用于终端的定位源代码崩溃位置的装置的方框图;
图14示意性示出了根据本发明的另一个实施例的应用于终端的定位源代码崩溃位置的装置的方框图;
图15示出了适于用来实现本发明实施例的服务器的计算机系统的结构示意图;
图16示出了适于用来实现本发明实施例的终端的计算机系统的结构示意图。
具体实施方式
现在将参考附图更全面地描述示例实施方式。然而,示例实施方式能够以多种形式实施,且不应被理解为限于在此阐述的范例;相反,提供这些实施方式使得本发明将更加全面和完整,并将示例实施方式的构思全面地传达给本领域的技术人员。
此外,所描述的特征、结构或特性可以以任何合适的方式结合在一个或更多实施例中。在下面的描述中,提供许多具体细节从而给出对本发明的实施例的充分理解。然而,本领域技术人员将意识到,可以实践本发明的技术方案而没有特定细节中的一个或更多,或者可以采用其它的方法、组元、装置、步骤等。在其它情况下,不详细示出或描述公知方法、装置、实现或者操作以避免模糊本发明的各方面。
附图中所示的方框图仅仅是功能实体,不一定必须与物理上独立的实体相对应。即,可以采用软件形式来实现这些功能实体,或在一个或多个硬件模块或集成电路中实现这些功能实体,或在不同网络和/或处理器装置和/或微控制器装置中实现这些功能实体。
附图中所示的流程图仅是示例性说明,不是必须包括所有的内容和操作/步骤,也不是必须按所描述的顺序执行。例如,有的操作/步骤还可以分解,而有的操作/步骤可以合并或部分合并,因此实际执行的顺序有可能根据实际情况改变。
图1示出了可以应用本发明实施例的定位源代码崩溃位置的方法或定位源代码崩溃位置的装置的示例性系统架构的示意图。
如图1所示,系统架构100可以包括终端设备101、102、103中的一种或多种,网络104和服务器105。网络104用以在终端设备101、102、103和服务器105之间提供通信链路的介质。网络104可以包括各种连接类型,例如有线、无线通信链路或者光纤电缆等等。
应该理解,图1中的终端设备、网络和服务器的数目仅仅是示意性的。根据实现需要,可以具有任意数目的终端设备、网络和服务器。比如服务器105可以是多个服务器组成的服务器集群等。
用户可以使用终端设备101、102、103通过网络104与服务器105交互,以接收或发送消息等。终端设备101、102、103可以是具有显示屏的各种电子设备,包括但不限于智能手机、平板电脑、便携式计算机和台式计算机等等。
服务器105可以是提供各种服务的服务器。例如服务器105可以接收由终端设备103(也可以是终端设备101或102)发送的崩溃日志(例如,第一崩溃日志或第二崩溃日志),其中,所述第一崩溃日志中包含模拟中央处理器的运行环境信息,所述第二崩溃日志中包含真实中央处理器的运行环境信息,服务器105可以根据模拟中央处理器的运行环境信息定位第一源代码的崩溃位置,或者根据真实中央处理器的运行环境信息定位第二源代码的崩溃位置,通过该方式可以准确定位到第一源代码或第二源代码的崩溃位置,从而提升了工作效率。。
在一些实施例中,本发明实施例所提供的定位源代码崩溃位置的方法可以由服务器105执行,相应地,定位源代码崩溃位置的装置可以设置于服务器105中。在另一些实施例中,本发明实施例所提供的定位源代码崩溃位置的方法可以由终端设备103(也可以是终端设备101或102)执行,相应地,定位源代码崩溃位置的装置可以设置于终端设备103(也可以是终端设备101或102)中。
图2示意性示出了根据本发明的实施例的应用于服务器的定位源代码崩溃位置的方法的流程图。
如图2所示,应用于服务器的定位源代码崩溃位置的方法可以包括步骤S210和步骤S220。
在步骤S210中,接收由终端的应用程序发送的第一崩溃日志,所述第一崩溃日志中包含模拟中央处理器的运行环境信息。
在步骤S220中,根据所述模拟中央处理器的运行环境信息定位第一源代码的崩溃位置。
该方法可以接收由终端的应用程序发送的第一崩溃日志,所述第一崩溃日志中包含模拟中央处理器的运行环境信息,然后根据该模拟中央处理器的运行环境信息定位第一源代码的崩溃位置,通过该方式可以准确定位到第一源代码的崩溃位置,从而提升了工作效率。
在本发明的一个实施例中,上述第一崩溃日志中可以包含模拟中央处理器的运行环境信息。其中,模拟中央处理器的运行环境信息可以包括以下任意一项或多项:虚拟化线程信息、虚拟化函数调用栈、虚拟化寄存器信息、虚拟化堆栈内存信息。在本实施例中,虚拟化线程信息、虚拟化函数调用栈、虚拟化寄存器信息、和/或虚拟化堆栈内存信息可以是通过终端中的第一信号处理函数采集的。例如,在终端检测到第一特定信号时,通过第一信号处理函数来完成崩溃上下文信息搜集和存储操作,即采集虚拟化线程信息、虚拟化函数调用栈、虚拟化寄存器信息、和/或虚拟化堆栈内存信息。在终端的应用程序下次启动时,可以通过该应用程序对虚拟化线程信息、虚拟化函数调用栈、虚拟化寄存器信息、和/或虚拟化堆栈内存信息发送至服务器,这样服务器可以根据虚拟化线程信息、虚拟化函数调用栈、虚拟化寄存器信息、和/或虚拟化堆栈内存信息快速准备的定位出源代码的崩溃位置。
在本发明的一个实施例中,根据上述模拟中央处理器的运行环境信息定位所述第一源代码的崩溃位置包括:根据上述模拟中央处理器的虚拟化函数调用栈、虚拟化线程信息和虚拟化寄存器中的程序计数器信息定位所述第一源代码的崩溃位置,通过该方式可以准确定位到第一源代码的崩溃位置,从而提升了工作效率。
在本发明的一个实施例中,在接收到第一崩溃日志之后,可以对其进行展示,这样可以帮助开发人员分析崩溃时的虚拟化后的代码运行环境,有效修复崩溃问题。例如,根据模拟中央处理器的其他虚拟化寄存器信息和虚拟化堆栈内存信息确定第一源代码的崩溃原因,其中,所述其他虚拟化寄存器信息为在所述虚拟化寄存器信息中除程序计数器信息之外的寄存器信息。
图3示意性示出了根据本发明的另一个实施例的应用于服务器的定位源代码崩溃位置的方法的流程图。
如图3所示,上述应用于服务器的定位源代码崩溃位置的方法还可以包括步骤S310和步骤S320。
在步骤S310中,接收由所述终端的应用程序发送的第二崩溃日志,所述第二崩溃日志中包含真实中央处理器的运行环境信息。
在步骤S320中,根据所述真实中央处理器的运行环境信息定位第二源代码的崩溃位置。
该方法可以接收由终端的应用程序发送的第二崩溃日志,所述第二崩溃日志中包含真实中央处理器的运行环境信息,然后根据该真实中央处理器的运行环境信息定位第二源代码的崩溃位置,通过该方式可以准确定位到第二源代码的崩溃位置,从而提升了工作效率。
在本发明的一个实施例中,上述真实中央处理器可以是终端中的CPU(全称central processing unit)。上述模拟中央处理器可以是通过动态二进制转化来的模拟CPU。其中,一个完整的真实中央处理器可以包括存储器、寄存器、指令译码器等部分,其中寄存器又通常分为通用寄存器、专用寄存器和控制寄存器。CPU从存储器中取出指令,通过指令译码器进行解释执行,执行时的信息使用寄存器和内存区域来保存,当前CPU执行的指令位置存储在程序计数器PC寄存器中。一个完整的模拟中央处理器可以包括模拟存储器、模拟寄存器、模拟指令译码器等部分。例如,在运行虚拟化后的代码时,虚拟机(虚拟化代码的解释器)中包含一个模拟CPU,其程序计数器PC寄存器中存储着当前解释执行的源代码位置。在本实施例中,可以通过程序计数器PC寄存器中存储的当前解释执行的源代码位置和其他崩溃时产生的上下文信息,如模拟函数调用栈,便可准确定位崩溃在源代码中的位置,并且根据其它模拟寄存器的值,便可辅助排查崩溃原因,快速修复崩溃。通过将上述崩溃信息(例如,第一崩溃日志)通过文件存储在终端,在下次启动应用程序时将其上传到服务器,这样便可在生产环境中及时获取崩溃信息,迅速止损。
在本发明的一个实施例中,上述第二崩溃日志中可以包含真实中央处理器的运行环境信息。其中,真实中央处理器的运行环境信息可以包括以下任意一项或多项:真实线程信息、真实函数调用栈、真实寄存器信息、真实堆栈内存信息。在本实施例中,真实线程信息、真实函数调用栈、真实寄存器信息、和/或真实堆栈内存信息可以是通过终端中的第二信号处理函数采集的。例如,在终端检测到第二特定信号时,通过第二信号处理函数来完成崩溃上下文信息搜集和存储操作,即采集真实线程信息、真实函数调用栈、真实寄存器信息、和/或真实堆栈内存信息。在终端的应用程序下次启动时,可以通过该应用程序对真实线程信息、真实函数调用栈、真实寄存器信息、和/或真实堆栈内存信息发送至服务器,这样服务器可以根据真实线程信息、真实函数调用栈、真实寄存器信息、和/或真实堆栈内存信息快速准备的定位出第二源代码的崩溃位置。
在本发明的一个实施例中,根据上述真实中央处理器的运行环境信息定位所述第二源代码的崩溃位置包括:根据上述真实中央处理器的真实函数调用栈、真实线程信息和真实寄存器中的程序计数器信息定位所述第二源代码的崩溃位置,通过该方式可以准确定位到第二源代码的崩溃位置,从而提升了工作效率。
在本发明的一个实施例中,在接收到第二崩溃日志之后,可以对其进行展示,这样可以帮助开发人员分析崩溃时的非虚拟化后的代码运行环境,有效修复崩溃问题。例如,根据真实中央处理器的其他真实寄存器信息和真实堆栈内存信息确定第二源代码的崩溃原因,其中,所述其他真实寄存器信息为在所述真实寄存器信息中除真实程序计数器信息之外的寄存器信息。
图4示意性示出了根据本发明的实施例的应用于终端的定位源代码崩溃位置的方法的流程图。
如图4所示,应用于终端的定位源代码崩溃位置的方法包括步骤S410~S450。
在步骤S410中,获取第一特定信号,所述第一特定信号包括在运行与应用程序相关的虚拟化后的代码过程中出现崩溃时产生的信号。
在步骤S420中,根据所述第一特定信号调用第一信号处理函数。
在步骤S430中,利用所述第一信号处理函数采集模拟中央处理器的运行环境信息。
在步骤S440中,基于所述模拟中央处理器的运行环境信息生成第一崩溃日志。
在步骤S450中,在所述应用程序下次启动时,向服务器发送所述第一崩溃日志,以使得所述服务器根据所述第一崩溃日志定位第一源代码的崩溃位置。
该方法可以获取在运行与应用程序相关的虚拟化后的代码过程中出现崩溃时产生的信号,根据该第一特定信号调用第一信号处理函数,利用第一信号处理函数可以采集模拟中央处理器的运行环境信息,基于所述模拟中央处理器的运行环境信息可以生成第一崩溃日志,在所述应用程序下次启动时,向服务器发送所述第一崩溃日志,以使得服务器根据该第一崩溃日志快速准备的定第一源代码的崩溃位置。
在本发明的一个实施例中,当终端运行与应用程序相关的虚拟化后的代码时,可以实时监控该应用程序,当检测到该应用程序发生异常或发生SEGMENTATION FAULT等事件时,终端的内核可以发出第一特定信号,如常见的SIGEGV和SIGBUS信号,在这种情况下,终端可以根据该第一特定信号调用第一信号处理函数进行响应。例如,利用第一信号处理函数采集模拟中央处理器的运行环境信息。在本实施例中,第一信号函数可以是预设信号处理函数中用于采集模拟中央处理器的运行环境信息的采集函数。例如,通过捕获SIGEGV或SIGBUS信号调用预设信号处理函数中相应的处理函数(例如,第一信号处理函数)来完成崩溃上下文的信息搜集和存储操作(即模拟中央处理器的运行环境信息)。
在本发明的一个实施例中,上述模拟中央处理器的运行环境信息包括以下任意一项或多项:虚拟化线程信息、虚拟化函数调用栈、虚拟化寄存器信息、虚拟化堆栈内存信息。例如,虚拟化线程号可以通过gettid函数获取;虚拟化函数调用栈可以通过结构体来构成,在虚拟化函数调用时将函数信息入栈返回时出栈,包含函数地址及重定向信息。
在本发明的一个实施例中,在利用所述第一信号处理函数采集模拟中央处理器的运行环境信息之后,可以利用崩溃信息记录函数对模拟中央处理器的运行环境信息进行记录并保存保存。
在本发明的一个实施例中,发送第一崩溃日志的时机可以设置为在上述应用程序下次启动时向服务器发送所述第一崩溃日志,这样有助于减少应用程序对异常或SEGMENTATION FAULT等事件处理的时间,使得用户感觉不到该应用程序的异常,从而提升用户体验。
图5示意性示出了根据本发明的另一个实施例的应用于终端的定位源代码崩溃位置的方法的流程图。
如图5所示,上述应用于终端的定位源代码崩溃位置的方法还包括步骤S510~S550。
在步骤S510中,获取第二特定信号,所述第二特定信号包括在运行与所述应用程序相关的非虚拟化后的代码过程中出现崩溃时产生的信号。
在步骤S520中,根据所述第二特定信号调用第二信号处理函数。
在步骤S530中,利用所述第二信号处理函数采集真实中央处理器的运行环境信息。
在步骤S540中,基于所述真实中央处理器的运行环境信息生成第二崩溃日志。
在步骤S550中,在所述应用程序下次启动时,向所述服务器发送所述第二崩溃日志,以使得所述服务器根据所述第二崩溃日志定位所述第二源代码的崩溃位置。
该方法可以获取在运行与应用程序相关的非虚拟化后的代码过程中出现崩溃时产生的信号,根据该第二特定信号调用第二信号处理函数,利用第二信号处理函数可以采集真实中央处理器的运行环境信息,基于所述真实中央处理器的运行环境信息可以生成第二崩溃日志,在所述应用程序下次启动时,向服务器发送所述第二崩溃日志,以使得服务器根据该第二崩溃日志快速准备的定第二源代码的崩溃位置。
在本发明的一个实施例中,当终端运行与应用程序相关的非虚拟化后的代码时,可以实时监控该应用程序,当检测到该应用程序发生异常或发生SEGMENTATION FAULT等事件时,终端的内核可以发出第二特定信号,如常见的SIGEGV和SIGBUS信号,在这种情况下,终端可以根据该第二特定信号调用第二信号处理函数进行响应。例如,利用第二信号处理函数采集真实中央处理器的运行环境信息。在本实施例中,第二信号函数可以是预设信号处理函数中用于采集真实中央处理器的运行环境信息的采集函数。例如,通过捕获SIGEGV或SIGBUS信号调用预设信号处理函数中相应的处理函数(例如,第二信号处理函数)来完成崩溃上下文的信息搜集和存储操作(即真实中央处理器的运行环境信息)。
在本发明的一个实施例中,上述真实中央处理器的运行环境信息包括以下任意一项或多项:真实线程信息、真实函数调用栈、真实寄存器信息、真实堆栈内存信息。例如,真实线程信息、真实寄存器信息、真实堆栈内存信息可以通过uc_mcontext的结构体指针获取,真实函数调用栈可以基于Google的breakpad库做二次开发来获取。
在本发明的一个实施例中,在利用所述第二信号处理函数采集真实中央处理器的运行环境信息之后,可以利用崩溃信息记录函数对真实中央处理器的运行环境信息进行记录并保存保存。
在本发明的一个实施例中,发送第二崩溃日志的时机可以设置为在上述应用程序下次启动时向服务器发送所述第二崩溃日志,这样有助于减少应用程序对异常或SEGMENTATION FAULT等事件处理的时间,使得用户感觉不到该应用程序的异常,从而提升用户体验。
图6示意性示出了根据本发明的另一个实施例的应用于终端的定位源代码崩溃位置的方法的流程图。
如图6所示,上述应用于终端的定位源代码崩溃位置的方法还包括步骤S610和S620。
在步骤S610中,在生成所述第一崩溃日志之后,将所述第一信号处理函数更新为终端系统的信号处理函数。
在步骤S620中,根据所述终端系统的信号处理函数退出所述应用程序。
该方法中在生成第一崩溃日志之后,将第一信号处理函数更新为终端系统的信号处理函数,根据终端系统的信号处理函数退出应用程序,这样可以减少用户等待的时间,进一步提升用户体验。
在本发明的一个实施例中,上述终端系统的信号处理函数可以为用于强制退出应用程序的函数。在本实施例中如果运行虚拟化后的代码发生崩溃,应用程序可能会出现卡顿现象,在这种情况下,需要根据终端系统的信号处理函数退出应用程序,这样可以减少用户等待的时间,进一步提升用户体验。
图7示意性示出了根据本发明的另一个实施例的应用于终端的定位源代码崩溃位置的方法的流程图。
如图7所示,上述应用于终端的定位源代码崩溃位置的方法还包括步骤S710和S720。
在步骤S710中,在生成所述第二崩溃日志之后,将所述第二信号处理函数更新为终端系统的信号处理函数。
在步骤S720中,根据所述终端系统的信号处理函数退出所述应用程序。
该方法中在生成第二崩溃日志之后,将第二信号处理函数更新为终端系统的信号处理函数,根据终端系统的信号处理函数退出应用程序,这样可以减少用户等待的时间,进一步提升用户体验。
在本发明的一个实施例中,上述终端系统的信号处理函数可以为用于强制退出应用程序的函数。在本实施例中如果运行非虚拟化后的代码发生崩溃,应用程序可能会出现卡顿现象,在这种情况下,需要根据终端系统的信号处理函数退出应用程序,这样可以减少用户等待的时间,进一步提升用户体验。
图8示意性示出了根据本发明的实施例的服务器和终端交互的示意图。
如图8所示,服务器和终端交互的过程具体如下:
S1:终端的应用程序获取在运行与应用程序相关的虚拟化后的代码或非虚拟化后的代码过程中出现崩溃时产生的信号(例如,第一特定信号或第二特定信号)。
S2:终端根据第一特定信号或第二特定信号调用与其对应的第一信号处理函数或第二信号处理函数。
S3:终端利用第一信号处理函数或第二信号处理函数采集与其对应的模拟中央处理器的运行环境信息或真实中央处理器的运行环境信息。
S4:终端基于模拟中央处理器的运行环境信息生成第一崩溃日志,以及基于真实中央处理器的运行环境信息生成第二崩溃日志。
S5:在生成第一崩溃日志或第二崩溃日志之后,终端将第一信号处理函数或第二信号处理函数更新为终端系统的信号处理函数,并根据终端系统的信号处理函数将上述应用程序强制退出。
S6:在上述应用程序下次启动时,终端向服务器发送第一崩溃日志或第二崩溃日志,以使得服务器根据第一崩溃日志或第二崩溃日志定位与其对应的第一源代码的崩溃位置或第二源代码的崩溃位置。
S7:服务器接收由终端的应用程序发送的第一崩溃日志或第二崩溃日志,所述第一崩溃日志中包含模拟中央处理器的运行环境信息,所述第二崩溃日志中包含真实中央处理器的运行环境信息。
S8:服务器根据模拟中央处理器的运行环境信息或真实中央处理器的运行环境信息定位与其对应的第一源代码的崩溃位置或第二源代码的崩溃位置。
图9示意性示出了根据本发明的实施例的应用于服务器的定位源代码崩溃位置的装置的方框图。
如图9所示,应用于服务器的定位源代码崩溃位置的装置200包括第一接收模块201和第一定位模块202。
具体地,第一接收模块201,用于接收由终端的应用程序发送的第一崩溃日志,所述第一崩溃日志中包含模拟中央处理器的运行环境信息。
第一定位模块202,用于根据所述模拟中央处理器的运行环境信息定位第一源代码的崩溃位置。
该应用于服务器的定位源代码崩溃位置的装置200可以接收由终端的应用程序发送的第一崩溃日志,所述第一崩溃日志中包含模拟中央处理器的运行环境信息,然后根据该模拟中央处理器的运行环境信息定位第一源代码的崩溃位置,通过该方式可以准确定位到第一源代码的崩溃位置,从而提升了工作效率。
根据本发明的实施例,该应用于服务器的定位源代码崩溃位置的装置200可以用于实现图2实施例描述的应用于服务器的定位源代码崩溃位置的方法。
图10示意性示出了根据本发明的另一个实施例的应用于服务器的定位源代码崩溃位置的装置的方框图。
如图10所示,上述应用于服务器的定位源代码崩溃位置的装置200还第二接收模块203和第二定位模块204。
具体地,第二接收模块203,用于接收由所述终端的应用程序发送的第二崩溃日志,所述第二崩溃日志中包含真实中央处理器的运行环境信息。
第二定位模块204,用于根据所述真实中央处理器的运行环境信息定位第二源代码的崩溃位置。
该应用于服务器的定位源代码崩溃位置的装置200可以接收由终端的应用程序发送的第二崩溃日志,所述第二崩溃日志中包含真实中央处理器的运行环境信息,然后根据该真实中央处理器的运行环境信息定位第二源代码的崩溃位置,通过该方式可以准确定位到第二源代码的崩溃位置,从而提升了工作效率。
根据本发明的实施例,该应用于服务器的定位源代码崩溃位置的装置200可以用于实现图3实施例描述的应用于服务器的定位源代码崩溃位置的方法。
由于本发明的示例实施例的应用于服务器的定位源代码崩溃位置的装置的各个模块可以用于实现上述图2和图3描述的应用于服务器的定位源代码崩溃位置的方法的示例实施例的步骤,因此对于本发明装置实施例中未披露的细节,请参照本发明上述的应用于服务器的定位源代码崩溃位置的方法的实施例。
可以理解的是,第一接收模块201、第一定位模块202、第二接收模块203、以及第二定位模块204可以合并在一个模块中实现,或者其中的任意一个模块可以被拆分成多个模块。或者,这些模块中的一个或多个模块的至少部分功能可以与其他模块的至少部分功能相结合,并在一个模块中实现。根据本发明的实施例,第一接收模块201、第一定位模块202、第二接收模块203、以及第二定位模块204中的至少一个可以至少被部分地实现为硬件电路,例如现场可编程门阵列(FPGA)、可编程逻辑阵列(PLA)、片上系统、基板上的系统、封装上的系统、专用集成电路(ASIC),或可以以对电路进行集成或封装的任何其他的合理方式等硬件或固件来实现,或以软件、硬件以及固件三种实现方式的适当组合来实现。或者,第一接收模块201、第一定位模块202、第二接收模块203、以及第二定位模块204中的至少一个可以至少被部分地实现为计算机程序模块,当该程序被计算机运行时,可以执行相应模块的功能。
图11示意性示出了根据本发明的实施例的应用于终端的定位源代码崩溃位置的装置的方框图。
如图11所示,应用于终端的定位源代码崩溃位置的装置300包括第一获取模块301、第一调用模块302、第一采集模块303、第一生成模块304和第一发送模块305。
具体地,第一获取模块301,用于获取第一特定信号,所述第一特定信号包括在运行与应用程序相关的虚拟化后的代码过程中出现崩溃时产生的信号。
第一调用模块302,用于根据所述第一特定信号调用第一信号处理函数。
第一采集模块303,利用所述第一信号处理函数采集模拟中央处理器的运行环境信息。
第一生成模块304,基于所述模拟中央处理器的运行环境信息生成第一崩溃日志。
第一发送模块305,在所述应用程序下次启动时,向服务器发送所述第一崩溃日志,以使得所述服务器根据所述第一崩溃日志定位第一源代码的崩溃位置。
该应用于终端的定位源代码崩溃位置的装置300可以获取在运行与应用程序相关的虚拟化后的代码过程中出现崩溃时产生的信号,根据该第一特定信号调用第一信号处理函数,利用第一信号处理函数可以采集模拟中央处理器的运行环境信息,基于所述模拟中央处理器的运行环境信息可以生成第一崩溃日志,在所述应用程序下次启动时,向服务器发送所述第一崩溃日志,以使得服务器根据该第一崩溃日志快速准备的定第一源代码的崩溃位置。
根据本发明的实施例,该应用于终端的定位源代码崩溃位置的装置300可以用于实现图4实施例描述的应用于终端的定位源代码崩溃位置的方法。
图12示意性示出了根据本发明的另一个实施例的应用于终端的定位源代码崩溃位置的装置的方框图。
如图12所示,上述应用于终端的定位源代码崩溃位置的装置300还包括第二获取模块306、第二调用模块307、第二采集模块308、第二生成模块309和第二发送模块310。
具体地,第二获取模块306,用于获取第二特定信号,所述第二特定信号包括在运行与所述应用程序相关的非虚拟化后的代码过程中出现崩溃时产生的信号。
第二调用模块307,用于根据所述第二特定信号调用第二信号处理函数。
第二采集模块308,利用所述第二信号处理函数采集真实中央处理器的运行环境信息。
第二生成模块309,基于所述真实中央处理器的运行环境信息生成第二崩溃日志。
第二发送模块310,在所述应用程序下次启动时,向所述服务器发送所述第二崩溃日志,以使得所述服务器根据所述第二崩溃日志定位所述第二源代码的崩溃位置。
该应用于终端的定位源代码崩溃位置的装置300可以获取在运行与应用程序相关的非虚拟化后的代码过程中出现崩溃时产生的信号,根据该第二特定信号调用第二信号处理函数,利用第二信号处理函数可以采集真实中央处理器的运行环境信息,基于所述真实中央处理器的运行环境信息可以生成第二崩溃日志,在所述应用程序下次启动时,向服务器发送所述第二崩溃日志,以使得服务器根据该第二崩溃日志快速准备的定第二源代码的崩溃位置。
根据本发明的实施例,该应用于终端的定位源代码崩溃位置的装置300可以用于实现图5实施例描述的应用于终端的定位源代码崩溃位置的方法。
图13示意性示出了根据本发明的另一个实施例的应用于终端的定位源代码崩溃位置的装置的方框图。
如图13所示,上述应用于终端的定位源代码崩溃位置的装置300还包括第一更新模块311和第一退出模块312。
具体地,第一更新模块311,在生成所述第一崩溃日志之后,将所述第一信号处理函数更新为终端系统的信号处理函数。
第一退出模块312,用于根据所述终端系统的信号处理函数退出所述应用程序。
该应用于终端的定位源代码崩溃位置的装置300中在生成第一崩溃日志之后,将第一信号处理函数更新为终端系统的信号处理函数,根据终端系统的信号处理函数退出应用程序,这样可以减少用户等待的时间,进一步提升用户体验。
根据本发明的实施例,该应用于终端的定位源代码崩溃位置的装置300可以用于实现图6实施例描述的应用于终端的定位源代码崩溃位置的方法。
图14示意性示出了根据本发明的另一个实施例的应用于终端的定位源代码崩溃位置的装置的方框图。
如图14所示,上述应用于终端的定位源代码崩溃位置的装置300还包括第二更新模块313和第二退出模块314。
具体地,第二更新模块313,在生成所述第二崩溃日志之后,将所述第二信号处理函数更新为终端系统的信号处理函数。
第一退出模块314,用于根据所述终端系统的信号处理函数退出所述应用程序。
该应用于终端的定位源代码崩溃位置的装置300中在生成第二崩溃日志之后,将第二信号处理函数更新为终端系统的信号处理函数,根据终端系统的信号处理函数退出应用程序,这样可以减少用户等待的时间,进一步提升用户体验。
根据本发明的实施例,该应用于终端的定位源代码崩溃位置的装置300可以用于实现图7实施例描述的应用于终端的定位源代码崩溃位置的方法。
由于本发明的示例实施例的应用于终端的定位源代码崩溃位置的装置的各个模块可以用于实现上述图4和图7描述的应用于终端的定位源代码崩溃位置的方法的示例实施例的步骤,因此对于本发明装置实施例中未披露的细节,请参照本发明上述的应用于终端的定位源代码崩溃位置的方法的实施例。
可以理解的是,第一获取模块301、第一调用模块302、第一采集模块303、第一生成模块304、第一发送模块305、第二获取模块306、第二调用模块307、第二采集模块308、第二生成模块309、第二发送模块310、第一更新模块311、第一退出模块312、第二更新模块313、以及第二退出模块314可以合并在一个模块中实现,或者其中的任意一个模块可以被拆分成多个模块。或者,这些模块中的一个或多个模块的至少部分功能可以与其他模块的至少部分功能相结合,并在一个模块中实现。根据本发明的实施例,第一获取模块301、第一调用模块302、第一采集模块303、第一生成模块304、第一发送模块305、第二获取模块306、第二调用模块307、第二采集模块308、第二生成模块309、第二发送模块310、第一更新模块311、第一退出模块312、第二更新模块313、以及第二退出模块314中的至少一个可以至少被部分地实现为硬件电路,例如现场可编程门阵列(FPGA)、可编程逻辑阵列(PLA)、片上系统、基板上的系统、封装上的系统、专用集成电路(ASIC),或可以以对电路进行集成或封装的任何其他的合理方式等硬件或固件来实现,或以软件、硬件以及固件三种实现方式的适当组合来实现。或者,第一获取模块301、第一调用模块302、第一采集模块303、第一生成模块304、第一发送模块305、第二获取模块306、第二调用模块307、第二采集模块308、第二生成模块309、第二发送模块310、第一更新模块311、第一退出模块312、第二更新模块313、以及第二退出模块314中的至少一个可以至少被部分地实现为计算机程序模块,当该程序被计算机运行时,可以执行相应模块的功能。
下面参考图15,其示出了适于用来实现本发明实施例的电子设备的计算机系统400的结构示意图。图15示出的电子设备(即上述服务器)的计算机系统400仅是一个示例,不应对本发明实施例的功能和使用范围带来任何限制。
如图15所示,计算机系统400包括中央处理单元(CPU)401,其可以根据存储在只读存储器(ROM)402中的程序或者从存储部分408加载到随机访问存储器(RAM)403中的程序而执行各种适当的动作和处理。在RAM 403中,还存储有系统操作所需的各种程序和数据。CPU401、ROM 402以及RAM 403通过总线404彼此相连。输入/输出(I/O)接口405也连接至总线404。
以下部件连接至I/O接口405:包括键盘、鼠标等的输入部分406;包括诸如阴极射线管(CRT)、液晶显示器(LCD)等以及扬声器等的输出部分407;包括硬盘等的存储部分408;以及包括诸如LAN卡、调制解调器等的网络接口卡的通信部分409。通信部分409经由诸如因特网的网络执行通信处理。驱动器410也根据需要连接至I/O接口405。可拆卸介质411,诸如磁盘、光盘、磁光盘、半导体存储器等等,根据需要安装在驱动器410上,以便于从其上读出的计算机程序根据需要被安装入存储部分408。
特别地,根据本发明的实施例,上文参考流程图描述的过程可以被实现为计算机软件程序。例如,本发明的实施例包括一种计算机程序产品,其包括承载在计算机可读介质上的计算机程序,该计算机程序包含用于执行流程图所示的方法的程序代码。在这样的实施例中,该计算机程序可以通过通信部分409从网络上被下载和安装,和/或从可拆卸介质411被安装。在该计算机程序被中央处理单元(CPU)401执行时,执行本申请的系统中限定的上述功能。
需要说明的是,本发明所示的计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质或者是上述两者的任意组合。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子可以包括但不限于:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机访问存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本发明中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。而在本发明中,计算机可读的信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。计算机可读的信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:无线、电线、光缆、RF等等,或者上述的任意合适的组合。
附图中的流程图和框图,图示了按照本发明各种实施例的系统、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,上述模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图或流程图中的每个方框、以及框图或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
描述于本发明实施例中所涉及到的单元可以通过软件的方式实现,也可以通过硬件的方式来实现,所描述的单元也可以设置在处理器中。其中,这些单元的名称在某种情况下并不构成对该单元本身的限定。
作为另一方面,本申请还提供了一种计算机可读介质,该计算机可读介质可以是上述实施例中描述的电子设备中所包含的;也可以是单独存在,而未装配入该电子设备中。上述计算机可读介质承载有一个或者多个程序,当上述一个或者多个程序被一个该电子设备执行时,使得该电子设备实现如上述实施例中所述的应用于服务器的定位源代码崩溃位置的方法。
例如,所述的电子设备(即上述服务器)可以实现如图2中所示的:在步骤S210中,接收由终端的应用程序发送的第一崩溃日志,所述第一崩溃日志中包含模拟中央处理器的运行环境信息。在步骤S220中,根据所述模拟中央处理器的运行环境信息定位第一源代码的崩溃位置。
应当注意,尽管在上文详细描述中提及了用于动作执行的设备的若干模块或者单元,但是这种划分并非强制性的。实际上,根据本发明的实施方式,上文描述的两个或更多模块或者单元的特征和功能可以在一个模块或者单元中具体化。反之,上文描述的一个模块或者单元的特征和功能可以进一步划分为由多个模块或者单元来具体化。
通过以上的实施方式的描述,本领域的技术人员易于理解,这里描述的示例实施方式可以通过软件实现,也可以通过软件结合必要的硬件的方式来实现。因此,根据本发明实施方式的技术方案可以以软件产品的形式体现出来,该软件产品可以存储在一个非易失性存储介质(可以是CD-ROM,U盘,移动硬盘等)中或网络上,包括若干指令以使得一台计算设备(可以是个人计算机、服务器、触控终端、或者网络设备等)执行根据本发明实施方式的方法。
下面参考图16,其示出了适于用来实现本发明实施例的电子设备的计算机系统500的结构示意图。图16示出的电子设备(即上述终端)的计算机系统500仅是一个示例,不应对本发明实施例的功能和使用范围带来任何限制。
如图16所示,计算机系统500包括中央处理单元(CPU)501,其可以根据存储在只读存储器(ROM)502中的程序或者从存储部分508加载到随机访问存储器(RAM)503中的程序而执行各种适当的动作和处理。在RAM 503中,还存储有系统操作所需的各种程序和数据。CPU501、ROM 502以及RAM 503通过总线504彼此相连。输入/输出(I/O)接口505也连接至总线504。
以下部件连接至I/O接口505:包括键盘、鼠标等的输入部分506;包括诸如阴极射线管(CRT)、液晶显示器(LCD)等以及扬声器等的输出部分507;包括硬盘等的存储部分508;以及包括诸如LAN卡、调制解调器等的网络接口卡的通信部分509。通信部分509经由诸如因特网的网络执行通信处理。驱动器510也根据需要连接至I/O接口505。可拆卸介质511,诸如磁盘、光盘、磁光盘、半导体存储器等等,根据需要安装在驱动器510上,以便于从其上读出的计算机程序根据需要被安装入存储部分508。
特别地,根据本发明的实施例,上文参考流程图描述的过程可以被实现为计算机软件程序。例如,本发明的实施例包括一种计算机程序产品,其包括承载在计算机可读介质上的计算机程序,该计算机程序包含用于执行流程图所示的方法的程序代码。在这样的实施例中,该计算机程序可以通过通信部分509从网络上被下载和安装,和/或从可拆卸介质511被安装。在该计算机程序被中央处理单元(CPU)501执行时,执行本申请的系统中限定的上述功能。
需要说明的是,本发明所示的计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质或者是上述两者的任意组合。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子可以包括但不限于:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机访问存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本发明中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。而在本发明中,计算机可读的信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。计算机可读的信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:无线、电线、光缆、RF等等,或者上述的任意合适的组合。
附图中的流程图和框图,图示了按照本发明各种实施例的系统、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,上述模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图或流程图中的每个方框、以及框图或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
描述于本发明实施例中所涉及到的单元可以通过软件的方式实现,也可以通过硬件的方式来实现,所描述的单元也可以设置在处理器中。其中,这些单元的名称在某种情况下并不构成对该单元本身的限定。
作为另一方面,本申请还提供了一种计算机可读介质,该计算机可读介质可以是上述实施例中描述的电子设备中所包含的;也可以是单独存在,而未装配入该电子设备中。上述计算机可读介质承载有一个或者多个程序,当上述一个或者多个程序被一个该电子设备执行时,使得该电子设备实现如上述实施例中所述的应用于终端的定位源代码崩溃位置的方法。
例如,所述的电子设备(即上述终端)可以实现如图4中所示的:在步骤S410中,获取第一特定信号,所述第一特定信号包括在运行与应用程序相关的虚拟化后的代码过程中出现崩溃时产生的信号。在步骤S420中,根据所述第一特定信号调用第一信号处理函数。在步骤S430中,利用所述第一信号处理函数采集模拟中央处理器的运行环境信。在步骤S440中,基于所述模拟中央处理器的运行环境信息生成第一崩溃日志。在步骤S450中,在所述应用程序下次启动时,向服务器发送所述第一崩溃日志,以使得所述服务器根据所述第一崩溃日志定位第一源代码的崩溃位置。
应当注意,尽管在上文详细描述中提及了用于动作执行的设备的若干模块或者单元,但是这种划分并非强制性的。实际上,根据本发明的实施方式,上文描述的两个或更多模块或者单元的特征和功能可以在一个模块或者单元中具体化。反之,上文描述的一个模块或者单元的特征和功能可以进一步划分为由多个模块或者单元来具体化。
通过以上的实施方式的描述,本领域的技术人员易于理解,这里描述的示例实施方式可以通过软件实现,也可以通过软件结合必要的硬件的方式来实现。因此,根据本发明实施方式的技术方案可以以软件产品的形式体现出来,该软件产品可以存储在一个非易失性存储介质(可以是CD-ROM,U盘,移动硬盘等)中或网络上,包括若干指令以使得一台计算设备(可以是个人计算机、服务器、触控终端、或者网络设备等)执行根据本发明实施方式的方法。
本领域技术人员在考虑说明书及实践这里公开的发明后,将容易想到本发明的其它实施方案。本申请旨在涵盖本发明的任何变型、用途或者适应性变化,这些变型、用途或者适应性变化遵循本发明的一般性原理并包括本发明未公开的本技术领域中的公知常识或惯用技术手段。说明书和实施例仅被视为示例性的,本发明的真正范围和精神由下面的权利要求指出。
应当理解的是,本发明并不局限于上面已经描述并在附图中示出的精确结构,并且可以在不脱离其范围进行各种修改和改变。本发明的范围仅由所附的权利要求来限制。
Claims (11)
1.一种定位源代码崩溃位置的方法,应用于服务器,其特征在于,包括:
接收由终端的应用程序发送的第一崩溃日志,所述第一崩溃日志中包含模拟中央处理器的运行环境信息,其中,在所述终端的应用程序启动时,接收由所述终端的应用程序发送的所述第一崩溃日志,所述第一崩溃日志为当终端运行与应用程序相关的虚拟化后的代码过程中出现崩溃的日志;
根据所述模拟中央处理器的运行环境信息定位第一源代码的崩溃位置;
其中,在接收由终端的应用程序发送的第一崩溃日志之后,还包括:展示所述第一崩溃日志,以分析崩溃时的虚拟化后的代码运行环境;
其中,所述模拟中央处理器的运行环境信息包括以下任意一项或多项:虚拟化线程信息、虚拟化函数调用栈、虚拟化寄存器信息、虚拟化堆栈内存信息;所述模拟中央处理器是通过动态二进制转化来的模拟中央处理器,所述模拟中央处理器存储有当前解释执行的源代码位置。
2.根据权利要求1所述的方法,其特征在于,根据所述模拟中央处理器的运行环境信息定位所述第一源代码的崩溃位置包括:
根据所述模拟中央处理器的虚拟化函数调用栈、虚拟化线程信息和虚拟化寄存器中的程序计数器信息定位所述第一源代码的崩溃位置。
3.根据权利要求1所述的方法,其特征在于,该方法还包括:
接收由所述终端的应用程序发送的第二崩溃日志,所述第二崩溃日志中包含真实中央处理器的运行环境信息;
根据所述真实中央处理器的运行环境信息定位第二源代码的崩溃位置。
4.一种定位源代码崩溃位置的方法,应用于终端,其特征在于,包括:
获取第一特定信号,所述第一特定信号包括在运行与应用程序相关的虚拟化后的代码过程中出现崩溃时产生的信号;
根据所述第一特定信号调用第一信号处理函数;
利用所述第一信号处理函数采集模拟中央处理器的运行环境信息;
基于所述模拟中央处理器的运行环境信息生成第一崩溃日志;
在所述应用程序下次启动时,向服务器发送所述第一崩溃日志,以使得所述服务器根据所述第一崩溃日志定位第一源代码的崩溃位置,其中,所述服务器还用于展示所述第一崩溃日志,以分析崩溃时的虚拟化后的代码运行环境;
其中,所述模拟中央处理器的运行环境信息包括以下任意一项或多项:虚拟化线程信息、虚拟化函数调用栈、虚拟化寄存器信息、虚拟化堆栈内存信息;所述模拟中央处理器是通过动态二进制转化来的模拟中央处理器,所述模拟中央处理器存储有当前解释执行的源代码位置。
5.根据权利要求4所述的方法,其特征在于,该方法还包括:
获取第二特定信号,所述第二特定信号包括在运行与所述应用程序相关的非虚拟化后的代码过程中出现崩溃时产生的信号;
根据所述第二特定信号调用第二信号处理函数;
利用所述第二信号处理函数采集真实中央处理器的运行环境信息;
基于所述真实中央处理器的运行环境信息生成第二崩溃日志;
在所述应用程序下次启动时,向所述服务器发送所述第二崩溃日志,以使得所述服务器根据所述第二崩溃日志定位第二源代码的崩溃位置。
6.根据权利要求4所述的方法,其特征在于,该方法还包括:
在生成所述第一崩溃日志之后,将所述第一信号处理函数更新为终端系统的信号处理函数;
根据所述终端系统的信号处理函数退出所述应用程序。
7.根据权利要求5所述的方法,其特征在于,该方法还包括:
在生成所述第二崩溃日志之后,将所述第二信号处理函数更新为终端系统的信号处理函数;
根据所述终端系统的信号处理函数退出所述应用程序。
8.一种定位源代码崩溃位置的装置,应用于服务器,其特征在于,包括:
第一接收模块,用于接收由终端的应用程序发送的第一崩溃日志,所述第一崩溃日志中包含模拟中央处理器的运行环境信息;
第一定位模块,用于根据所述模拟中央处理器的运行环境信息定位第一源代码的崩溃位置;
其中,所述第一接收模块,还被配置为:在所述终端的应用程序启动时,接收由所述终端的应用程序发送的所述第一崩溃日志,所述第一崩溃日志为当终端运行与应用程序相关的虚拟化后的代码过程中出现崩溃的日志;
其中,所述第一接收模块,还被配置为:展示所述第一崩溃日志,以分析崩溃时的虚拟化后的代码运行环境;
其中,所述模拟中央处理器的运行环境信息包括以下任意一项或多项:虚拟化线程信息、虚拟化函数调用栈、虚拟化寄存器信息、虚拟化堆栈内存信息;所述模拟中央处理器是通过动态二进制转化来的模拟中央处理器,所述模拟中央处理器存储有当前解释执行的源代码位置。
9.一种定位源代码崩溃位置的装置,应用于终端,其特征在于,包括:
第一获取模块,用于获取第一特定信号,所述第一特定信号包括在运行与应用程序相关的虚拟化后的代码过程中出现崩溃时产生的信号;
第一调用模块,用于根据所述第一特定信号调用第一信号处理函数;
第一采集模块,利用所述第一信号处理函数采集模拟中央处理器的运行环境信息;
第一生成模块,基于所述模拟中央处理器的运行环境信息生成第一崩溃日志;
第一发送模块,在所述应用程序下次启动时,向服务器发送所述第一崩溃日志,以使得所述服务器根据所述第一崩溃日志定位第一源代码的崩溃位置,其中,所述服务器还用于展示所述第一崩溃日志,以分析崩溃时的虚拟化后的代码运行环境;
其中,所述模拟中央处理器的运行环境信息包括以下任意一项或多项:虚拟化线程信息、虚拟化函数调用栈、虚拟化寄存器信息、虚拟化堆栈内存信息;所述模拟中央处理器是通过动态二进制转化来的模拟中央处理器,所述模拟中央处理器存储有当前解释执行的源代码位置。
10.一种电子设备,包括:
一个或多个处理器;以及
存储装置,用于存储一个或多个程序,当所述一个或多个程序被所述一个或多个处理器执行时,使得所述一个或多个处理器实现根据权利要求1~3任意一项所述的方法或权利要求4~7任意一项所述的方法。
11.一种计算机可读介质,其上存储有计算机程序,其特征在于,所述程序被处理器执行时实现根据权利要求1~3任意一项所述的方法或权利要求4~7任意一项所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010131329.7A CN111367799B (zh) | 2020-02-28 | 2020-02-28 | 定位源代码崩溃位置的方法、装置、介质及电子设备 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010131329.7A CN111367799B (zh) | 2020-02-28 | 2020-02-28 | 定位源代码崩溃位置的方法、装置、介质及电子设备 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN111367799A CN111367799A (zh) | 2020-07-03 |
CN111367799B true CN111367799B (zh) | 2024-05-07 |
Family
ID=71211165
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202010131329.7A Active CN111367799B (zh) | 2020-02-28 | 2020-02-28 | 定位源代码崩溃位置的方法、装置、介质及电子设备 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN111367799B (zh) |
Families Citing this family (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112084086B (zh) * | 2020-08-14 | 2024-03-22 | 北京字节跳动网络技术有限公司 | 一种信息收集方法、装置、介质和电子设备 |
CN112416583A (zh) * | 2020-11-17 | 2021-02-26 | 平安科技(深圳)有限公司 | 高频请求处理方法、装置、电子设备及存储介质 |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN106649089A (zh) * | 2016-10-09 | 2017-05-10 | 武汉斗鱼网络科技有限公司 | 一种程序崩溃分析方法及系统 |
CN110069403A (zh) * | 2019-03-21 | 2019-07-30 | 深圳壹账通智能科技有限公司 | 定位崩溃事件的方法及装置、存储介质、电子装置 |
CN110489345A (zh) * | 2019-08-08 | 2019-11-22 | 北京字节跳动网络技术有限公司 | 一种崩溃聚合方法、装置、介质和设备 |
CN110764945A (zh) * | 2019-10-23 | 2020-02-07 | 北京博睿宏远数据科技股份有限公司 | 一种崩溃日志处理方法、装置、设备和存储介质 |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102063367B (zh) * | 2010-10-29 | 2013-07-17 | 凌阳科技股份有限公司 | 针对当机程序的离线分析方法及装置 |
-
2020
- 2020-02-28 CN CN202010131329.7A patent/CN111367799B/zh active Active
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN106649089A (zh) * | 2016-10-09 | 2017-05-10 | 武汉斗鱼网络科技有限公司 | 一种程序崩溃分析方法及系统 |
CN110069403A (zh) * | 2019-03-21 | 2019-07-30 | 深圳壹账通智能科技有限公司 | 定位崩溃事件的方法及装置、存储介质、电子装置 |
CN110489345A (zh) * | 2019-08-08 | 2019-11-22 | 北京字节跳动网络技术有限公司 | 一种崩溃聚合方法、装置、介质和设备 |
CN110764945A (zh) * | 2019-10-23 | 2020-02-07 | 北京博睿宏远数据科技股份有限公司 | 一种崩溃日志处理方法、装置、设备和存储介质 |
Also Published As
Publication number | Publication date |
---|---|
CN111367799A (zh) | 2020-07-03 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN109739478B (zh) | 前端项目自动化构建方法、装置、存储介质及电子设备 | |
US11392461B2 (en) | Method and apparatus for processing information | |
CN111427803B (zh) | 自动化随机测试方法、装置、计算机设备及介质 | |
CN111338623B (zh) | 一种开发用户界面的方法、装置、介质和电子设备 | |
CN109656646B (zh) | 一种远程桌面控制方法、装置、设备及虚拟化芯片 | |
CN107918555B (zh) | 基于物理主机的用于处理数据的方法和装置 | |
CN113127050B (zh) | 一种应用资源打包过程监控方法、装置、设备和介质 | |
CN111367799B (zh) | 定位源代码崩溃位置的方法、装置、介质及电子设备 | |
US10318343B2 (en) | Migration methods and apparatuses for migrating virtual machine including locally stored and shared data | |
CN104598267A (zh) | 应用的调起方法及装置 | |
CN111786823A (zh) | 基于分布式服务的故障模拟方法及装置 | |
CN110347601B (zh) | 脚本进程的中断处理方法和装置 | |
CN111414154A (zh) | 前端开发的方法、装置、电子设备和存储介质 | |
CN113220374A (zh) | 软件处理方法和装置 | |
CN112506781B (zh) | 测试监控方法、装置、电子设备、存储介质及程序产品 | |
CN116051031A (zh) | 项目调度系统、介质及电子设备 | |
CN111385661A (zh) | 语音控制全屏播放的方法及终端 | |
CN112882921B (zh) | 故障模拟方法和装置 | |
CN111679885B (zh) | 确定虚拟机漂移方法、装置、介质及电子设备 | |
CN114510334A (zh) | 类实例的调用方法、装置、电子设备及自动驾驶车辆 | |
CN114490266A (zh) | 一种数据采集方法、装置、设备及存储介质 | |
CN113918444A (zh) | 崩溃源代码定位方法、装置、介质及电子设备 | |
CN111443983B (zh) | 应用程序的虚拟化方法、装置、电子设备及存储介质 | |
CN112379973A (zh) | 重载方法和装置 | |
CN111813407A (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 |