CN114020505A - 一种数据处理方法、装置、电子设备及存储介质 - Google Patents

一种数据处理方法、装置、电子设备及存储介质 Download PDF

Info

Publication number
CN114020505A
CN114020505A CN202111216763.6A CN202111216763A CN114020505A CN 114020505 A CN114020505 A CN 114020505A CN 202111216763 A CN202111216763 A CN 202111216763A CN 114020505 A CN114020505 A CN 114020505A
Authority
CN
China
Prior art keywords
class
function
application program
address
storage structure
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.)
Granted
Application number
CN202111216763.6A
Other languages
English (en)
Other versions
CN114020505B (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.)
Beijing 58 Information Technology Co Ltd
Original Assignee
Beijing 58 Information 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 Beijing 58 Information Technology Co Ltd filed Critical Beijing 58 Information Technology Co Ltd
Priority to CN202111216763.6A priority Critical patent/CN114020505B/zh
Publication of CN114020505A publication Critical patent/CN114020505A/zh
Application granted granted Critical
Publication of CN114020505B publication Critical patent/CN114020505B/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/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/0703Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation
    • G06F11/0706Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation the processing taking place on a specific hardware platform or in a specific software environment
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/0703Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation
    • G06F11/079Root cause analysis, i.e. error or fault diagnosis

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Quality & Reliability (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Health & Medical Sciences (AREA)
  • Biomedical Technology (AREA)
  • Stored Programmes (AREA)

Abstract

本发明提供了一种数据处理方法、装置、电子设备及存储介质。通过本申请,在确定崩溃相关的指令所属的函数的函数名时,可以不使用应用程序的符号表,脱离了对应用程序的符号表的依赖,也不受应用程序的UUID的影响,如此可以提高本方案的适用范围。另外,symbolicatecrash工具需要依赖MAC OS的运行环境,而本申请的方案可以不使用symbolicatecrash工具,从而可以避免受MAC OS的运行环境的局限,本申请的方案除了可以应用在MAC OS的运行环境中,还可以运行在Linux的运行环境以及Winows的运行环境中等,从而可以提高本方案的适用范围等。

Description

一种数据处理方法、装置、电子设备及存储介质
技术领域
本发明涉及计算机技术领域,尤其涉及一种数据处理方法、装置、电子设备及存储介质。
背景技术
随着技术的飞速发展,越来越多的用户在手机上安装应用程序并使用。应用程序在手机上运行的过程中有时候会崩溃(例如闪退等),为了避免之后再次出现崩溃,可以对应用程序中的引起崩溃的源代码进行修改,以对应用程序优化。
为了使得开发人员能够对引起崩溃的源代码进行修改,则首先需要在应用程序的源代码中定位出引起崩溃的源代码。
在一个方式中,可以使用symbolicatecrash工具结合应用程序的符号表解析应用程序崩溃时产生的崩溃日志,以定位出应用程序中的引起崩溃的指令所在的函数。
然而,发明人发现,在上述方式中,解析崩溃时产生的崩溃日志时需要使用到应用程序的符号表,如果应用程序的符号表已经从应用程序中剥离,则会无法获取到应用程序的符号表,进而就无法定位出应用程序中的引起崩溃的指令所在的函数,增加了开发人员解决崩溃问题的难度。
发明内容
本申请示出了一种数据处理方法、装置、电子设备及存储介质。
第一方面,本申请示出了一种数据处理方法,所述方法包括:
在应用程序运行的过程中崩溃的情况下,获取崩溃相关的指令在应用程序中的指令起始地址;
根据应用程序中的代码段中的类地址字段中记录的内容,获取应用程序包括的类中的至少部分类的类信息的存储结构分别在应用程序中的类起始地址;
对于至少部分类中的任意一个类,确定在所述代码段中的类信息字段中的所述类的类信息的存储结构,根据所述类的类信息的存储结构、所述类的类信息的存储结构在应用程序中的类起始地址以及类信息字段中记录的内容,获取所述类中的各个函数分别在应用程序中的函数地址区间;
在获取的函数地址区间中筛选崩溃相关的指令在应用程序中的指令起始地址所在的目标函数地址区间;
根据所述目标函数地址区间输出所述崩溃相关的指令所属的函数的函数名。
在一个可选的实现方式中,所述根据所述类的类信息的存储结构、所述类的类信息的存储结构在应用程序中的类起始地址以及类信息字段中记录的内容,获取所述类中的各个函数分别在应用程序中的函数地址区间,包括:
根据所述类的类信息的存储结构以及所述类的类信息的存储结构在应用程序中的类起始地址,在类信息字段中记录的内容中,获取所述类中的各个函数分别在应用程序中的函数起始地址;
根据所述类中的各个函数分别在应用程序中的函数起始地址以及代码段中的函数指令段中记录的内容,获取所述类中的各个函数分别在应用程序中的函数地址区间。
在一个可选的实现方式中,所述根据所述类的类信息的存储结构以及所述类的类信息的存储结构在应用程序中的类起始地址,在类信息字段中记录的内容中,获取所述类中的各个函数分别在应用程序中的函数起始地址,包括:
根据所述类的类信息的存储结构以及所述类的类信息的存储结构在应用程序中的类起始地址,在类信息字段中记录的内容中,确定所述类中包括的函数的数量;
根据所述类的类信息的存储结构、所述类的类信息的存储结构在应用程序中的类起始地址以及所述数量,在类信息字段中记录的内容中,获取所述类中的各个函数分别在应用程序中的函数起始地址。
在一个可选的实现方式中,所述根据所述类的类信息的存储结构以及所述类的类信息的存储结构在应用程序中的类起始地址,在类信息字段中记录的内容中,确定所述类中包括的函数的数量,包括:
根据所述类的类信息的存储结构以及所述类的类信息的存储结构在应用程序中的类起始地址,在类信息字段中记录的内容中,确定所述类的类信息的存储结构中的数量字符串,数量字符串用于指示所述类中包括的函数的数量;
根据所述数量字符串确定所述类中包括的函数的数量。
在一个可选的实现方式中,所述根据所述类的类信息的存储结构、所述类的类信息的存储结构在应用程序中的类起始地址以及所述数量,在类信息字段中记录的内容中,获取所述类中的各个函数分别在应用程序中的函数起始地址,包括:
根据所述类的类信息的存储结构、所述类的类信息的存储结构在应用程序中的类起始地址以及所述数量,在类信息字段中记录的内容中,分别确定所述类中的各个函数的地址字符串,函数的地址字符串用于指示函数在应用程序中的函数起始地址;
根据各个函数的地址字符串分别确定各个函数分别在应用程序中的函数起始地址。
在一个可选的实现方式中,所述根据所述类中的各个函数分别在应用程序中的函数起始地址以及代码段中的函数指令段中记录的内容,获取所述类中的各个函数分别在应用程序中的函数地址区间,包括:
对于所述类中的任意一个函数,可以根据所述函数在应用程序中的函数起始地址以及代码段中的函数指令段中记录的内容,确定所述函数中包括的各个指令所占的空间大小;
根据所述函数在应用程序中的函数起始地址以及所述函数中包括的各个指令所占的空间大小,获取所述函数在应用程序中的函数结束地址;
根据所述函数起始地址以及所述函数结束地址获取所述函数在应用程序中的函数地址区间。
在一个可选的实现方式中,所述根据应用程序中的代码段中的类地址字段中记录的内容,获取应用程序包括的类中的至少部分类的类信息的存储结构分别在应用程序中的类起始地址,包括:
获取类地址字段在应用程序中的段起始地址,以及,确定类地址字段的存储结构;
根据类地址字段的存储结构以及所述段起始地址,在类地址字段中记录的内容中,获取应用程序中的类中的至少部分类中的各个类的类信息的存储结构的偏移量,任意一个类的类信息的存储结构的偏移量包括:所述类的类信息的存储结构在应用程序中的类起始地址与位于所述类之前且与所述类相邻的类的存储结构在应用程序中的类起始地址之间的距离;
根据所述段起始地址以及至少部分类中的各个类的类信息的存储结构的偏移量,分别获取至少部分类中的各个类的类信息的存储结构在应用程序中的类起始地址。
第二方面,本申请示出了一种数据处理装置,所述装置包括:
第一获取模块,用于在应用程序运行的过程中崩溃的情况下,获取崩溃相关的指令在应用程序中的指令起始地址;
第二获取模块,用于根据应用程序中的代码段中的类地址字段中记录的内容,获取应用程序包括的类中的至少部分类的类信息的存储结构分别在应用程序中的类起始地址;
确定模块,用于对于至少部分类中的任意一个类,确定在所述代码段中的类信息字段中的所述类的类信息的存储结构,第三获取模块,用于根据所述类的类信息的存储结构、所述类的类信息的存储结构在应用程序中的类起始地址以及类信息字段中记录的内容,获取所述类中的各个函数分别在应用程序中的函数地址区间;
筛选模块,用于在获取的函数地址区间中筛选崩溃相关的指令在应用程序中的指令起始地址所在的目标函数地址区间;
输出模块,用于根据所述目标函数地址区间输出所述崩溃相关的指令所属的函数的函数名。
在一个可选的实现方式中,所述第三获取模块包括:
第一获取单元,用于根据所述类的类信息的存储结构以及所述类的类信息的存储结构在应用程序中的类起始地址,在类信息字段中记录的内容中,获取所述类中的各个函数分别在应用程序中的函数起始地址;
第二获取单元,用于根据所述类中的各个函数分别在应用程序中的函数起始地址以及代码段中的函数指令段中记录的内容,获取所述类中的各个函数分别在应用程序中的函数地址区间。
在一个可选的实现方式中,所述第一获取单元包括:
第一确定子单元,用于根据所述类的类信息的存储结构以及所述类的类信息的存储结构在应用程序中的类起始地址,在类信息字段中记录的内容中,确定所述类中包括的函数的数量;
第一获取子单元,用于根据所述类的类信息的存储结构、所述类的类信息的存储结构在应用程序中的类起始地址以及所述数量,在类信息字段中记录的内容中,获取所述类中的各个函数分别在应用程序中的函数起始地址。
在一个可选的实现方式中,所述第一确定子单元具体用于:根据所述类的类信息的存储结构以及所述类的类信息的存储结构在应用程序中的类起始地址,在类信息字段中记录的内容中,确定所述类的类信息的存储结构中的数量字符串,数量字符串用于指示所述类中包括的函数的数量;根据所述数量字符串确定所述类中包括的函数的数量。
在一个可选的实现方式中,所述第一获取子单元具体用于:根据所述类的类信息的存储结构、所述类的类信息的存储结构在应用程序中的类起始地址以及所述数量,在类信息字段中记录的内容中,分别确定所述类中的各个函数的地址字符串,函数的地址字符串用于指示函数在应用程序中的函数起始地址;根据各个函数的地址字符串分别确定各个函数分别在应用程序中的函数起始地址。
在一个可选的实现方式中,所述第二获取单元包括:
第二确定子单元,用于对于所述类中的任意一个函数,可以根据所述函数在应用程序中的函数起始地址以及代码段中的函数指令段中记录的内容,确定所述函数中包括的各个指令所占的空间大小;
第二获取子单元,用于根据所述函数在应用程序中的函数起始地址以及所述函数中包括的各个指令所占的空间大小,获取所述函数在应用程序中的函数结束地址;
第三获取子单元,用于根据所述函数起始地址以及所述函数结束地址获取所述函数在应用程序中的函数地址区间。
在一个可选的实现方式中,所述第二获取模块包括:
第三获取单元,用于获取类地址字段在应用程序中的段起始地址,以及,确定单元,用于确定类地址字段的存储结构;
第四获取单元,用于根据类地址字段的存储结构以及所述段起始地址,在类地址字段中记录的内容中,获取应用程序中的类中的至少部分类中的各个类的类信息的存储结构的偏移量,任意一个类的类信息的存储结构的偏移量包括:所述类的类信息的存储结构在应用程序中的类起始地址与位于所述类之前且与所述类相邻的类的存储结构在应用程序中的类起始地址之间的距离;
第五获取单元,用于根据所述段起始地址以及至少部分类中的各个类的类信息的存储结构的偏移量,分别获取至少部分类中的各个类的类信息的存储结构在应用程序中的类起始地址。
第三方面,本申请示出了一种电子设备,所述电子设备包括:
处理器;
用于存储处理器可执行指令的存储器;
其中,所述处理器被配置为执行如第一方面所述的数据处理方法。
第四方面,本申请示出了一种非临时性计算机可读存储介质,当所述存储介质中的指令由电子设备的处理器执行时,使得电子设备能够执行如第一方面所述的数据处理方法。
第五方面,本申请示出了一种计算机程序产品,当所述计算机程序产品中的指令由电子设备的处理器执行时,使得电子设备能够执行如第一方面所述的数据处理方法。
本申请提供的技术方案可以包括以下有益效果:
在本申请中,在应用程序运行的过程中崩溃的情况下,获取崩溃相关的指令在应用程序中的指令起始地址。根据应用程序中的代码段中的类地址字段中记录的内容,获取应用程序包括的类中的至少部分类的类信息的存储结构分别在应用程序中的类起始地址。对于至少部分类中的任意一个类,确定在代码段中的类信息字段中的该类的类信息的存储结构,根据在代码段中的类信息字段中的该类的类信息的存储结构、该类的类信息的存储结构在应用程序中的类起始地址以及类信息字段中记录的内容,获取该类中的各个函数分别在应用程序中的函数地址区间。在获取的函数地址区间中筛选崩溃相关的指令在应用程序中的指令起始地址所在的目标函数地址区间;根据目标函数地址区间输出崩溃相关的指令所属的函数的函数名。
通过本申请,在确定崩溃相关的指令所属的函数的函数名时,可以不使用应用程序的符号表,脱离了对应用程序的符号表的依赖,也不受应用程序的UUID(UniversallyUnique Identifier,通用唯一识别码)的影响,如此可以提高本方案的适用范围。
另外,symbolicatecrash工具需要依赖MAC OS的运行环境,而本申请的方案可以不使用symbolicatecrash工具,从而可以避免受MAC OS的运行环境的局限,本申请的方案除了可以应用在MAC OS的运行环境中,还可以运行在Linux的运行环境以及Winows的运行环境中等,从而可以提高本方案的适用范围等。
附图说明
图1是本申请示出的一种数据处理方法的步骤流程图。
图2是本申请示出的一种数据处理装置的结构框图。
图3是本申请示出的一种电子设备的框图。
图4是本申请示出的一种电子设备的框图。
具体实施方式
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
参照图1,示出了本申请的一种数据处理方法的步骤流程图,应用于电子设备,该方法具体可以包括如下步骤:
在步骤S101中,在应用程序运行的过程中崩溃的情况下,获取崩溃相关的指令在应用程序中的指令起始地址。
在应用程序运行的过程中崩溃的情况下,可以自动生成崩溃日志,崩溃日志中可以包括崩溃堆栈。
崩溃堆栈中可以包括应用程序中的崩溃相关的指令内存地址等。指令的内存地址包括应用程序加载在内存之后,指令在内存中的地址等。
崩溃相关的指令可以理解为引起应用程序崩溃的指令,例如,应用程序中的一个或多个指令出现故障,导致应用程序崩溃,则该一个或多个指令可以理解为崩溃相关的指令。
因此,可以从崩溃日志中提取崩溃堆栈,然后可以从崩溃堆栈中提取应用程序中的崩溃相关的指令的内存地址。
然后可以根据崩溃相关的指令的内存地址获取崩溃相关的指令在应用程序中的指令起始地址。例如,可以计算崩溃相关的指令的内存地址与应用程序在内存中的起始地址之间的差值,然后根据该差值获取崩溃相关的指令在应用程序中的指令起始地址。
在基于arm64的系统的情况下,在应用程序加载在内存中之后,应用程序的头部具有pagezero,pagezero的起始地址与pagezero结束地址之间的距离为0x10000000,因此,在计算崩溃相关的指令在应用程序中的指令起始地址时,可以消除0x10000000的影响,所以,可以计算该差值与0x10000000之间的差值,得到崩溃相关的指令在应用程序中的指令起始地址。
在步骤S102中,根据应用程序中的代码段中的类地址字段中记录的内容,获取应用程序包括的类中的至少部分类的类信息的存储结构分别在应用程序中的类起始地址。
在本申请中,本步骤可以通过如下流程实现,包括:
1021、获取类地址字段在应用程序中的段起始地址,以及,确定类地址字段的存储结构。
在本申请中,类地址字段位于应用程序中的代码段中。
在一个实施例中,应用程序可以包括Mach-O文件等,代码段包括_text段,类地址字段包括_types字段,例如,_swift5_types等。
类地址字段中存储有类地址字段在应用程序中的段起始地址,因此,可以直接在类地址字段中获取类地址字段在应用程序中的段起始地址。
另外,类地址字段中还存储了应用程序中的各个类的类信息的存储结构的偏移量,应用程序中的各个类在应用程序中的顺序与类地址字段中存储的各个类的类信息的存储结构的偏移量的顺序相同。
在本申请一个实施例中,各个类的类信息的存储结构的偏移量所占的字符串的位数可以是固定的,也可以是相同的。例如,各个类的类信息的存储结构的偏移量均占8位字符串等。
例如,对于应用程序中的顺序相邻的任意两个类,根据前一个类的类信息的存储结构在应用程序中的类起始地址与后一个类在应用程序类信息的存储结构的偏移量,可以得到后一个类的类信息的存储结构在应用程序中的类起始地址。
在类地址字段的存储结构确定之后,类地址字段中按照顺序包括哪些内容就确定了,且类地址字段中的各个内容所占的字符串的位数也就确定的。
如此,类地址字段中的哪些位的字符串代表哪些类的类信息的存储结构的偏移量就可以确定,例如,类地址字段中连续的各个8位的字符串依次表示各个类的类信息的存储结构的偏移量。
1022、根据类地址字段的存储结构以及类地址字段在应用程序中的段起始地址,在类地址字段中记录的内容中,获取应用程序中的类中的至少部分类中的各个类的类信息的存储结构的偏移量,任意一个类的类信息的存储结构的偏移量包括:该类的类信息的存储结构在应用程序中的类起始地址与位于该类之前且与该类相邻的类的存储结构在应用程序中的类起始地址之间的距离。
例如,根据类地址字段的存储结构以及类地址字段在应用程序中的段起始地址,可以在类地址字段的存储结构中依次获取每固定位数的字符串。
对于获取的任一个固定位数的字符串,可以将获取的该固定位数的字符串组合(例如,可以按照字符串由高位至低位的顺序组合)得到一个类的类信息的存储结构的偏移量。
例如,在类地址字段的存储结构中依次获取每8位的字符串,对于获取的任意8位的字符串,将获取的该8位字符串组合为一个类的类信息的存储结构的偏移量。
对于获取的其他每一个固定位数的字符串,同样如此。
1023、根据类地址字段在应用程序中的段起始地址以及应用程序中的类中的至少部分类中的各个类的类信息的存储结构的偏移量分别获取至少部分类中的各个类的类信息的存储结构在应用程序中的类起始地址。
在本申请中,可以根据类地址字段在应用程序中的段起始地址与类地址字段中的第一个类的类信息的存储结构的偏移量,获取第一个类的类信息的存储结构在应用程序中的类起始地址。
例如,可以计算类地址字段在应用程序中的段起始地址与第一个类的类信息的存储结构的偏移量之间的和值,然后根据该和值获取第一个类的类信息的存储结构在应用程序中的类起始地址。
在一个例子中,在基于arm64的系统的情况下,在应用程序加载在内存中之后,应用程序的头部具有pagezero,pagezero的起始地址与pagezero结束地址之间的距离为0x10000000,因此,在第一个类的类信息的存储结构在应用程序中的类起始地址时,可以消除0x10000000的影响,所以,可以计算该和值与0x10000000之间的差值,得到第一个类的类信息的存储结构在应用程序中的类起始地址。
另外,可以根据第一个类的类信息的存储结构在应用程序中的类起始地址与类地址字段中的第二个类的类信息的存储结构的偏移量,获取第二个类的类信息的存储结构在应用程序中的类起始地址(计算方式同上)。
另外,可以根据第二个类的类信息的存储结构在应用程序中的类起始地址与类地址字段中的第三个类的类信息的存储结构的偏移量,获取第三个类的类信息的存储结构在应用程序中的类起始地址(计算方式同上),以此类推,可以根据第N-1个类的类信息的存储结构在应用程序中的类起始地址与类地址字段中的第N个类的类信息的存储结构的偏移量,获取第N个类的类信息的存储结构在应用程序中的类起始地址(计算方式同上),N为应用程序中包括的类的数量。
在步骤S103中,对于至少部分类中的任意一个类,确定在代码段中的类信息字段中的该类的类信息的存储结构,根据在代码段中的类信息字段中的该类的类信息的存储结构、该类的类信息的存储结构在应用程序中的类起始地址以及类信息字段中记录的内容,获取该类中的各个函数分别在应用程序中的函数地址区间。
在本申请中,类信息字段位于应用程序中的代码段中。
在一个实施例中,应用程序可以包括Mach-O文件等,代码段包括_text段,类信息字段可以包括_const字段等。
另外,类信息字段中还以存储结构的形式存储了应用程序中的各个类的类信息,应用程序中的各个类在应用程序中的顺序与类信息字段中存储的各个类的类信息的顺序相同。
对于任一个类的类信息,该存储结构中每固定位数的字符串用于指示该类的不同种类的信息等,例如,每8位的字符串用于指示该类的不同种类的信息等。
例如,对于任意一个类,在该类的类信息的存储结构中,第一个8位的字符串为类型字符串,用于指示该类的类型,例如,class类型、struct类型或枚举类型等。
第二个8位的字符串为重写函数地址字符串,用于指示该类的父类对该类重写的函数的地址等。
第三个8位的字符串为类名称字符串,用于指示该类的名称的应用程序中的存储地址的偏移量等。
第四个8位的字符串为类属性数量字符串,用于指示该类的属性的数量等。
第五个8位的字符串为类的属性地址字符串,用于指示该类的属性的存储结构在应用程序中的起始地址等......
第十三个8位的字符串为函数数量字符串,用于指示该类中包括的函数的数量。
第十四个8位字符串用于指示该类中的第一个函数的函数类型,例如,类函数、实例函数、init函数、get函数、set函数、modify函数或read函数等,第(十四+2N)个8位字符串用于指示该类中的第N+1个函数(如果存在的话)的函数类型。N+1为该类中包括的函数的数量。
第十五个8位字符串用于指示该类中的第一个函数在应用程序中的起始地址,第(十五+2N)个8位字符串用于指示该类中的第N+1个函数(如果存在的话)在应用程序中的起始地址。
在该类的类信息的存储结构确定之后,该类的类信息的存储结构中按照顺序包括哪些内容就确定了,且该类的类信息的存储结构中的各个内容所占的字符串的位数也就确定的。
如此,该类的类信息的存储结构中的哪些位的字符串代表该类的哪些种类的信息就可以确定,例如,该类的类信息的存储结构中以连续的各个8位的字符串依次表示该类的各个种类的信息等。
另外,在本申请一个实施例中,根据在代码段中的类信息字段中的该类的类信息的存储结构、该类的类信息的存储结构在应用程序中的类起始地址以及类信息字段中记录的内容,获取该类中的各个函数分别在应用程序中的函数地址区间,包括:
1031、根据在代码段中的类信息字段中的该类的类信息的存储结构以及该类的类信息的存储结构在应用程序中的类起始地址,在类信息字段中记录的内容中,获取该类中的各个函数分别在应用程序中的函数起始地址。
在本申请一个实施例中,步骤1031可以通过如下11)~12)的流程实现,包括:
11)、根据在代码段中的类信息字段中的该类的类信息的存储结构以及该类的类信息的存储结构在应用程序中的类起始地址,在类信息字段中记录的内容中,确定该类中包括的函数的数量。
根据在代码段中的类信息字段中的该类的类信息的存储结构以及该类的类信息的存储结构在应用程序中的类起始地址,在类信息字段中记录的内容中,确定该类的类信息的存储结构中的数量字符串。数量字符串用于指示该类中包括的函数的数量。之后可以根据数量字符串确定该类中包括的函数的数量。
在一个例子中,例如,在类信息字段中记录的内容中,确定该类的类信息的存储结构中的数量字符串时,可以根据该类的类信息的存储结构在应用程序中的类起始地址,在类信息字段中记录的内容中,确定该类的类信息的存储结构中的第一个8位字符串,然后以第一个8位字符串为基准,在该类的类信息的存储结构中,确定用于指示该类中包括的函数的数量的第十三个8位字符串。
12)、根据在代码段中的类信息字段中的该类的类信息的存储结构、该类的类信息的存储结构在应用程序中的类起始地址以及该类中包括的函数的数量,在类信息字段中记录的内容中,获取该类中的各个函数分别在应用程序中的函数起始地址。
在本申请中,可以根据在代码段中的类信息字段中的该类的类信息的存储结构、该类的类信息的存储结构在应用程序中的类起始地址以及该类中包括的函数的数量,在类信息字段中记录的内容中,分别确定该类中的各个函数的地址字符串,函数的地址字符串用于指示函数在应用程序中的函数起始地址。然后根据各个函数的地址字符串分别确定各个函数分别在应用程序中的函数起始地址。
在一个例子中,例如,在类信息字段中记录的内容中,分别确定该类中的各个函数的地址字符串时,可以根据该类的类信息的存储结构在应用程序中的类起始地址,在类信息字段中记录的内容中,确定该类的类信息的存储结构中的第一个8位字符串,然后以第一个8位字符串为基准,在该类的类信息的存储结构中,确定用于指示第1个函数在应用程序中的函数起始地址的第十五个8位字符串......以及用于指示第N个函数在应用程序中的函数起始地址的第(十五+2N-2)个8位字符串(如果存在的话)。
1032、根据该类中的各个函数分别在应用程序中的函数起始地址以及代码段中的函数指令段中记录的内容,获取该类中的各个函数分别在应用程序中的函数地址区间。
在本申请中,对于该类中的任意一个函数,可以根据该函数在应用程序中的函数起始地址以及代码段中的函数指令段中记录的内容,确定该函数中包括的各个指令所占的空间大小。
例如,可以根据该函数在应用程序中的函数起始地址在应用程序中的代码段中的函数指令段(用于存储应用程序中的类中的函数中的指令)中确定该函数的第1个指令,然后从第1个指令开始遍历指令,直至遍历到一个结束指令(是一个特殊的指令,电子设备可以识别出哪些指令为结束指令)为止,即为该函数的结束指令,遍历到的指令即为该函数中包括的指令,然后可以获取遍历到的各个指令所占的空间大小。
之后,可以根据该函数在应用程序中的函数起始地址以及该函数中包括的各个指令所占的空间大小获取该函数在应用程序中的函数结束地址。例如,可以计算该函数中包括的各个指令所占的空间大小之间的第一和值,然后计算第一和值与该函数在应用程序中的函数起始地址之间的第二和值,并作为该函数在应用程序中的函数结束地址。
之后可以根据函数起始地址以及函数结束地址获取该函数在应用程序中的函数地址区间。例如,可以将函数起始地址作为函数地址区间的左端点,将函数结束地址作为函数地址区间的右端点,从而组成该函数在应用程序中的函数地址区间。
对于该类中的其他每一个函数,同样如此。
在步骤S104中,在获取的函数地址区间中筛选崩溃相关的指令在应用程序中的指令起始地址所在的目标函数地址区间。
其中,在崩溃相关的指令在应用程序中的指令起始地址大于或等于获取的函数地址区间的左端点且小于或等于获取的函数地址区间的右端点的情况下,则说明崩溃相关的指令在应用程序中的指令起始地址位于目标函数地址区间中,崩溃相关的指令位于目标函数地址区间所属的函数中。
在步骤S105中,根据目标函数地址区间输出崩溃相关的指令所属的函数的函数名。
例如,目标函数地址区间所属的函数即为崩溃相关的指令所属的函数,因此,可以输出目标函数地址区间所属的函数的函数名。
在本申请一个实施例中,可以在电子设备的屏幕上显示崩溃相关的指令所属的函数的函数名。
或者,在本申请一个实施例中,可以使用电子设备的音响播放崩溃相关的指令所属的函数的函数名。
在开发人员感知到该提示信息之后,就可以获知崩溃相关的指令所属的函数的函数名,进而开发人员根据崩溃相关的指令所属的函数的函数名就可以快速定位出应用程序的崩溃相关的函数的源代码,并对应用程序的崩溃相关的函数的源代码修改,以实现对应用程序优化,尽可能地避免之后由于崩溃相关的函数导致的应用程序崩溃。
或者,在本申请一个实施例中,还可以在电子设备中的预设文件中记录崩溃相关的指令所属的函数的函数名,以供开发人员之后在需要的时候在预设文件中可以查看崩溃相关的指令所属的函数的函数名。
或者,在本申请一个实施例中,还可以将崩溃相关的指令所属的函数的函数名通过邮件、短信或PUSH消息等任何可用方式发送给相关开发人员,以供开发人员查看崩溃相关的指令所属的函数的函数名等。
在本申请中,在应用程序运行的过程中崩溃的情况下,获取崩溃相关的指令在应用程序中的指令起始地址。根据应用程序中的代码段中的类地址字段中记录的内容,获取应用程序包括的类中的至少部分类的类信息的存储结构分别在应用程序中的类起始地址。对于至少部分类中的任意一个类,确定在代码段中的类信息字段中的该类的类信息的存储结构,根据在代码段中的类信息字段中的该类的类信息的存储结构、该类的类信息的存储结构在应用程序中的类起始地址以及类信息字段中记录的内容,获取该类中的各个函数分别在应用程序中的函数地址区间。在获取的函数地址区间中筛选崩溃相关的指令在应用程序中的指令起始地址所在的目标函数地址区间;根据目标函数地址区间输出崩溃相关的指令所属的函数的函数名。
通过本申请,在确定崩溃相关的指令所属的函数的函数名时,可以不使用应用程序的符号表,脱离了对应用程序的符号表的依赖,也不受应用程序的UUID的影响,如此可以提高本方案的适用范围。
另外,symbolicatecrash工具需要依赖MAC OS的运行环境,而本申请的方案可以不使用symbolicatecrash工具,从而可以避免受MAC OS的运行环境的局限,本申请的方案除了可以应用在MAC OS的运行环境中,还可以运行在Linux的运行环境以及Winows的运行环境中等,从而可以提高本方案的适用范围等。
在本申请中,对于任意一个类而言,如果确定出崩溃相关的指令位于一个类中的一个函数中,则可以通过在代码段中的类信息字段中的该类的类信息的存储结构、该类的类信息的存储结构在应用程序中的类起始地址以及该类中包括的函数的数量,获取用于指示该类的名称的应用程序中的存储地址的偏移量的类名称字符串,然后根据类名称字符串以及该类的类信息的存储结构在应用程序中的类起始地址的偏移量获取该类的名称的应用程序中的存储地址,然后根据该类的名称的应用程序中的存储地址在stringtable中获取该类的名称,并输出该类的名称,以给开发人员查看,以帮助开发人员优化该函数。
在本申请中,对于任意一个类而言,如果确定出崩溃相关的指令位于一个类中的一个函数中,则可以通过在代码段中的类信息字段中的该类的类信息的存储结构、该类的类信息的存储结构在应用程序中的类起始地址以及该类中包括的函数的数量,获取指示该类中的该函数的函数类型的类型字符串,然后根据指示该类中的该函数的函数类型的类型字符串判断该函数的类型,例如,可以对类型字符串与特定字符串运算(例如,类型字符串为10进制的字符串,可以对类型字符串与特定的16进制的字符串进行与运算,特定的16进制字符串包括0x0f以及0x等),得到一个新的字符串,然后根据新的字符串确定函数的类型,例如,不同值的新的字符串对应不同的类型,例如,一个值的新的字符串对应init类型,另一个值的新的字符串对应get类型,又一个值的新的字符串对应set类型,又一个值的新的字符串对应modify类型,又一个值的新的字符串对应read类型等。
之后可以并输出该函数的类型,以给开发人员查看,以帮助开发人员优化该函数。
其次,还可以通过在代码段中的类信息字段中的该类的类信息的存储结构、该类的类信息的存储结构在应用程序中的类起始地址以及该类中包括的函数的数量,获取用于指示该类的类型的类型字符串,类型字符串可以为16进制的字符串,可以将16进制的字符串转换为二进制的字符串,取二进制的字符串中的低5位的二进制字符串,然后将低5位的二进制字符串转换为10进制字符串,然后根据10进制的字符串确定类的类型,例如,不同的10进制的字符串对应不同的类型,例如,一个10进制的字符串对应class类型,另一个10进制的字符串对应struct类型,又一个10进制的字符串对应枚举类型等。
之后可以输出该类的类型,以给开发人员查看,以帮助开发人员优化该函数。
另外,16进制字符串转化得到的二进制字符串中的高两位的字符串分别用于指示类中是否存在虚函数表以及类的父类对该类重写的函数。
如果存在虚函数表和/或存在类的父类对该类重写的函数,则说明该类中存在函数,因此,可以不跳过该类。需要判断崩溃的指令是否属于该类中的函数中。
如果不存在虚函数表以及不存在类的父类对该类重写的函数,则说明该类中不存在函数,因此,可以跳过该类,例如可以不判断崩溃的指令是否位于该类中,直接对下一个类进行遍历,例如,可以判断下一个类中是否存在函数,从而可以提高效率。
在本申请中,在应用程序运行的过程中崩溃的情况下,崩溃相关的指令可能为多个,不同的崩溃相关的指令在应用程序中的指令起始地址不同,在这种情况下,可以将各个崩溃相关的指令在应用程序中的指令起始地址按照由低至高的顺序排序,这样,步骤S101中,可以按照排序顺序先获取最低的指令起始地址。
然后针对最低的指令起始地址,可以在代码段中的类信息字段中开始由低位至高位遍历,直至遍历在代码段中的类信息字段中的一个类的类信息的存储结构且确定出最低的指令起始地址对应的崩溃相关的指令属于该一个类中的函数为止。
之后,可以按照排序顺序获取次低的指令起始地址。
然后针对次低的指令起始地址,可以在代码段中的类信息字段中的该一个类的类信息的存储结构之后开始由低位至高位遍历(可以不从类信息字段的开始遍历)。
直至遍历在代码段中的类信息字段中的另一个类的类信息的存储结构且确定出次低的指令起始地址对应的崩溃相关的指令属于该另一个类中的函数为止。
之后,可以按照排序顺序获取第三低的指令起始地址。
然后针对第三低的指令起始地址,可以在代码段中的类信息字段中的该另一个类的类信息的存储结构之后开始由低位至高位遍历(可以不从类信息字段的开始遍历)。
直至遍历在代码段中的类信息字段中的又一个类的类信息的存储结构且确定出第三低的指令起始地址对应的崩溃相关的指令属于该又一个类中的函数为止。
以此类推,依次获取更高的指令起始地址,直至依次根据各个指令起始地址确定出崩溃相关的指令所在的函数为止。
通过本申请,可以仅仅遍历一次类信息字段,避免针对每一个指令起始地址均从类信息字段的开头开始遍历,从而可以降低遍历的数据量,进而可缩短时间,提高效率。
需要说明的是,对于方法实施例,为了简单描述,故将其都表述为一系列的动作组合,但是本领域技术人员应该知悉,本申请并不受所描述的动作顺序的限制,因为依据本申请,某些步骤可以采用其他顺序或者同时进行。其次,本领域技术人员也应该知悉,说明书中所描述的实施例均属于可选实施例,所涉及的动作并不一定是本申请所必须的。
参照图2,示出了本申请的一种数据处理装置的结构框图,应用于电子设备,该装置具体可以包括如下模块:
第一获取模块11,用于在应用程序运行的过程中崩溃的情况下,获取崩溃相关的指令在应用程序中的指令起始地址;
第二获取模块12,用于根据应用程序中的代码段中的类地址字段中记录的内容,获取应用程序包括的类中的至少部分类的类信息的存储结构分别在应用程序中的类起始地址;
确定模块13,用于对于至少部分类中的任意一个类,确定在所述代码段中的类信息字段中的所述类的类信息的存储结构,第三获取模块14,用于根据所述类的类信息的存储结构、所述类的类信息的存储结构在应用程序中的类起始地址以及类信息字段中记录的内容,获取所述类中的各个函数分别在应用程序中的函数地址区间;
筛选模块15,用于在获取的函数地址区间中筛选崩溃相关的指令在应用程序中的指令起始地址所在的目标函数地址区间;
输出模块16,用于根据所述目标函数地址区间输出所述崩溃相关的指令所属的函数的函数名。
在一个可选的实现方式中,所述第三获取模块包括:
第一获取单元,用于根据所述类的类信息的存储结构以及所述类的类信息的存储结构在应用程序中的类起始地址,在类信息字段中记录的内容中,获取所述类中的各个函数分别在应用程序中的函数起始地址;
第二获取单元,用于根据所述类中的各个函数分别在应用程序中的函数起始地址以及代码段中的函数指令段中记录的内容,获取所述类中的各个函数分别在应用程序中的函数地址区间。
在一个可选的实现方式中,所述第一获取单元包括:
第一确定子单元,用于根据所述类的类信息的存储结构以及所述类的类信息的存储结构在应用程序中的类起始地址,在类信息字段中记录的内容中,确定所述类中包括的函数的数量;
第一获取子单元,用于根据所述类的类信息的存储结构、所述类的类信息的存储结构在应用程序中的类起始地址以及所述数量,在类信息字段中记录的内容中,获取所述类中的各个函数分别在应用程序中的函数起始地址。
在一个可选的实现方式中,所述第一确定子单元具体用于:根据所述类的类信息的存储结构以及所述类的类信息的存储结构在应用程序中的类起始地址,在类信息字段中记录的内容中,确定所述类的类信息的存储结构中的数量字符串,数量字符串用于指示所述类中包括的函数的数量;根据所述数量字符串确定所述类中包括的函数的数量。
在一个可选的实现方式中,所述第一获取子单元具体用于:根据所述类的类信息的存储结构、所述类的类信息的存储结构在应用程序中的类起始地址以及所述数量,在类信息字段中记录的内容中,分别确定所述类中的各个函数的地址字符串,函数的地址字符串用于指示函数在应用程序中的函数起始地址;根据各个函数的地址字符串分别确定各个函数分别在应用程序中的函数起始地址。
在一个可选的实现方式中,所述第二获取单元包括:
第二确定子单元,用于对于所述类中的任意一个函数,可以根据所述函数在应用程序中的函数起始地址以及代码段中的函数指令段中记录的内容,确定所述函数中包括的各个指令所占的空间大小;
第二获取子单元,用于根据所述函数在应用程序中的函数起始地址以及所述函数中包括的各个指令所占的空间大小,获取所述函数在应用程序中的函数结束地址;
第三获取子单元,用于根据所述函数起始地址以及所述函数结束地址获取所述函数在应用程序中的函数地址区间。
在一个可选的实现方式中,所述第二获取模块包括:
第三获取单元,用于获取类地址字段在应用程序中的段起始地址,以及,确定单元,用于确定类地址字段的存储结构;
第四获取单元,用于根据类地址字段的存储结构以及所述段起始地址,在类地址字段中记录的内容中,获取应用程序中的类中的至少部分类中的各个类的类信息的存储结构的偏移量,任意一个类的类信息的存储结构的偏移量包括:所述类的类信息的存储结构在应用程序中的类起始地址与位于所述类之前且与所述类相邻的类的存储结构在应用程序中的类起始地址之间的距离;
第五获取单元,用于根据所述段起始地址以及至少部分类中的各个类的类信息的存储结构的偏移量,分别获取至少部分类中的各个类的类信息的存储结构在应用程序中的类起始地址。
在本申请中,在应用程序运行的过程中崩溃的情况下,获取崩溃相关的指令在应用程序中的指令起始地址。根据应用程序中的代码段中的类地址字段中记录的内容,获取应用程序包括的类中的至少部分类的类信息的存储结构分别在应用程序中的类起始地址。对于至少部分类中的任意一个类,确定在代码段中的类信息字段中的该类的类信息的存储结构,根据在代码段中的类信息字段中的该类的类信息的存储结构、该类的类信息的存储结构在应用程序中的类起始地址以及类信息字段中记录的内容,获取该类中的各个函数分别在应用程序中的函数地址区间。在获取的函数地址区间中筛选崩溃相关的指令在应用程序中的指令起始地址所在的目标函数地址区间;根据目标函数地址区间输出崩溃相关的指令所属的函数的函数名。
通过本申请,在确定崩溃相关的指令所属的函数的函数名时,可以不使用应用程序的符号表,脱离了对应用程序的符号表的依赖,也不受应用程序的UUID的影响,如此可以提高本方案的适用范围。
另外,symbolicatecrash工具需要依赖MAC OS的运行环境,而本申请的方案可以不使用symbolicatecrash工具,从而可以避免受MAC OS的运行环境的局限,本申请的方案除了可以应用在MAC OS的运行环境中,还可以运行在Linux的运行环境以及Winows的运行环境中等,从而可以提高本方案的适用范围等。
对于装置实施例而言,由于其与方法实施例基本相似,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。
可选的,本发明实施例还提供了一种电子设备,包括:处理器,存储器,存储在存储器上并可在处理器上运行的计算机程序,该计算机程序被处理器执行时实现上述数据处理方法实施例的各个过程,且能达到相同的技术效果,为避免重复,这里不再赘述。
本发明实施例还提供了一种计算机可读存储介质,计算机可读存储介质上存储有计算机程序,计算机程序被处理器执行时实现上述数据处理方法实施例的各个过程,且能达到相同的技术效果,为避免重复,这里不再赘述。其中,所述的计算机可读存储介质,如只读存储器(Read-Only Memory,简称ROM)、随机存取存储器(Random Access Memory,简称RAM)、磁碟或者光盘等。
图3是本申请示出的一种电子设备800的框图。例如,电子设备800可以是移动电话,计算机,数字广播终端,消息收发设备,游戏控制台,平板设备,医疗设备,健身设备,个人数字助理等。
参照图3,电子设备800可以包括以下一个或多个组件:处理组件802,存储器804,电力组件806,多媒体组件808,音频组件810,输入/输出(I/O)的接口812,传感器组件814,以及通信组件816。
处理组件802通常控制电子设备800的整体操作,诸如与显示,电话呼叫,数据通信,相机操作和记录操作相关联的操作。处理组件802可以包括一个或多个处理器820来执行指令,以完成上述方法的全部或部分步骤。此外,处理组件802可以包括一个或多个模块,便于处理组件802和其他组件之间的交互。例如,处理组件802可以包括多媒体模块,以方便多媒体组件808和处理组件802之间的交互。
存储器804被配置为存储各种类型的数据以支持在设备800的操作。这些数据的示例包括用于在电子设备800上操作的任何应用程序或方法的指令,联系人数据,电话簿数据,消息,图像,视频等。存储器804可以由任何类型的易失性或非易失性存储设备或者它们的组合实现,如静态随机存取存储器(SRAM),电可擦除可编程只读存储器(EEPROM),可擦除可编程只读存储器(EPROM),可编程只读存储器(PROM),只读存储器(ROM),磁存储器,快闪存储器,磁盘或光盘。
电源组件806为电子设备800的各种组件提供电力。电源组件806可以包括电源管理系统,一个或多个电源,及其他与为电子设备800生成、管理和分配电力相关联的组件。
多媒体组件808包括在所述电子设备800和用户之间的提供一个输出接口的屏幕。在一些实施例中,屏幕可以包括液晶显示器(LCD)和触摸面板(TP)。如果屏幕包括触摸面板,屏幕可以被实现为触摸屏,以接收来自用户的输入信号。触摸面板包括一个或多个触摸传感器以感测触摸、滑动和触摸面板上的手势。所述触摸传感器可以不仅感测触摸或滑动动作的边界,而且还检测与所述触摸或滑动操作相关的持续时间和压力。在一些实施例中,多媒体组件808包括一个前置摄像头和/或后置摄像头。当设备800处于操作模式,如拍摄模式或视频模式时,前置摄像头和/或后置摄像头可以接收外部的多媒体数据。每个前置摄像头和后置摄像头可以是一个固定的光学透镜系统或具有焦距和光学变焦能力。
音频组件810被配置为输出和/或输入音频信号。例如,音频组件810包括一个麦克风(MIC),当电子设备800处于操作模式,如呼叫模式、记录模式和语音识别模式时,麦克风被配置为接收外部音频信号。所接收到的音频信号可以被进一步存储在存储器804或经由通信组件816发送。在一些实施例中,音频组件810还包括一个扬声器,用于输出音频信号。
I/O接口812为处理组件802和外围接口模块之间提供接口,上述外围接口模块可以是键盘,点击轮,按钮等。这些按钮可包括但不限于:主页按钮、音量按钮、启动按钮和锁定按钮。
传感器组件814包括一个或多个传感器,用于为电子设备800提供各个方面的状态评估。例如,传感器组件814可以检测到设备800的打开/关闭状态,组件的相对定位,例如所述组件为电子设备800的显示器和小键盘,传感器组件814还可以检测电子设备800或电子设备800一个组件的位置改变,用户与电子设备800接触的存在或不存在,电子设备800方位或加速/减速和电子设备800的温度变化。传感器组件814可以包括接近传感器,被配置用来在没有任何的物理接触时检测附近物体的存在。传感器组件814还可以包括光传感器,如CMOS或CCD图像传感器,用于在成像应用中使用。在一些实施例中,该传感器组件814还可以包括加速度传感器,陀螺仪传感器,磁传感器,压力传感器或温度传感器。
通信组件816被配置为便于电子设备800和其他设备之间有线或无线方式的通信。电子设备800可以接入基于通信标准的无线网络,如WiFi,运营商网络(如2G、3G、4G或5G),或它们的组合。在一个示例性实施例中,通信组件816经由广播信道接收来自外部广播管理系统的广播信号或广播操作信息。在一个示例性实施例中,所述通信组件816还包括近场通信(NFC)模块,以促进短程通信。例如,在NFC模块可基于射频识别(RFID)技术,红外数据协会(IrDA)技术,超宽带(UWB)技术,蓝牙(BT)技术和其他技术来实现。
在示例性实施例中,电子设备800可以被一个或多个应用专用集成电路(ASIC)、数字信号处理器(DSP)、数字信号处理设备(DSPD)、可编程逻辑器件(PLD)、现场可编程门阵列(FPGA)、控制器、微控制器、微处理器或其他电子元件实现,用于执行上述方法。
在示例性实施例中,还提供了一种包括指令的非临时性计算机可读存储介质,例如包括指令的存储器804,上述指令可由电子设备800的处理器820执行以完成上述方法。例如,所述非临时性计算机可读存储介质可以是ROM、随机存取存储器(RAM)、CD-ROM、磁带、软盘和光数据存储设备等。
图4是本申请示出的一种电子设备1900的框图。例如,电子设备1900可以被提供为一服务器。
参照图4,电子设备1900包括处理组件1922,其进一步包括一个或多个处理器,以及由存储器1932所代表的存储器资源,用于存储可由处理组件1922的执行的指令,例如应用程序。存储器1932中存储的应用程序可以包括一个或一个以上的每一个对应于一组指令的模块。此外,处理组件1922被配置为执行指令,以执行上述方法。
电子设备1900还可以包括一个电源组件1926被配置为执行电子设备1900的电源管理,一个有线或无线网络接口1950被配置为将电子设备1900连接到网络,和一个输入输出(I/O)接口1958。电子设备1900可以操作基于存储在存储器1932的操作系统,例如Windows ServerTM,Mac OS XTM,UnixTM,LinuxTM,FreeBSDTM或类似。
需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者装置不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者装置所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、方法、物品或者装置中还存在另外的相同要素。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端(可以是手机,计算机,服务器,空调器,或者网络设备等)执行本发明各个实施例所述的方法。
上面结合附图对本发明的实施例进行了描述,但是本发明并不局限于上述的具体实施方式,上述的具体实施方式仅仅是示意性的,而不是限制性的,本领域的普通技术人员在本发明的启示下,在不脱离本发明宗旨和权利要求所保护的范围情况下,还可做出很多形式,均属于本发明的保护之内。
本领域普通技术人员可以意识到,结合本发明实施例中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、或者计算机软件和电子硬件的结合来实现。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本发明的范围。
所属领域的技术人员可以清楚地了解到,为描述的方便和简洁,上述描述的系统、装置和单元的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。
在本申请所提供的实施例中,应该理解到,所揭露的装置和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如,所述单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,装置或单元的间接耦合或通信连接,可以是电性,机械或其它的形式。
所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
另外,在本发明各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。
所述功能如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本发明各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:U盘、移动硬盘、ROM、RAM、磁碟或者光盘等各种可以存储程序代码的介质。
以上所述,仅为本发明的具体实施方式,但本发明的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本发明揭露的技术范围内,可轻易想到变化或替换,都应涵盖在本发明的保护范围之内。因此,本发明的保护范围应以权利要求的保护范围为准。

Claims (16)

1.一种数据处理方法,其特征在于,所述方法包括:
在应用程序运行的过程中崩溃的情况下,获取崩溃相关的指令在应用程序中的指令起始地址;
根据应用程序中的代码段中的类地址字段中记录的内容,获取应用程序包括的类中的至少部分类的类信息的存储结构分别在应用程序中的类起始地址;
对于至少部分类中的任意一个类,确定在所述代码段中的类信息字段中的所述类的类信息的存储结构,根据所述类的类信息的存储结构、所述类的类信息的存储结构在应用程序中的类起始地址以及类信息字段中记录的内容,获取所述类中的各个函数分别在应用程序中的函数地址区间;
在获取的函数地址区间中筛选崩溃相关的指令在应用程序中的指令起始地址所在的目标函数地址区间;
根据所述目标函数地址区间输出所述崩溃相关的指令所属的函数的函数名。
2.根据权利要求1所述的方法,其特征在于,所述根据所述类的类信息的存储结构、所述类的类信息的存储结构在应用程序中的类起始地址以及类信息字段中记录的内容,获取所述类中的各个函数分别在应用程序中的函数地址区间,包括:
根据所述类的类信息的存储结构以及所述类的类信息的存储结构在应用程序中的类起始地址,在类信息字段中记录的内容中,获取所述类中的各个函数分别在应用程序中的函数起始地址;
根据所述类中的各个函数分别在应用程序中的函数起始地址以及代码段中的函数指令段中记录的内容,获取所述类中的各个函数分别在应用程序中的函数地址区间。
3.根据权利要求2所述的方法,其特征在于,所述根据所述类的类信息的存储结构以及所述类的类信息的存储结构在应用程序中的类起始地址,在类信息字段中记录的内容中,获取所述类中的各个函数分别在应用程序中的函数起始地址,包括:
根据所述类的类信息的存储结构以及所述类的类信息的存储结构在应用程序中的类起始地址,在类信息字段中记录的内容中,确定所述类中包括的函数的数量;
根据所述类的类信息的存储结构、所述类的类信息的存储结构在应用程序中的类起始地址以及所述数量,在类信息字段中记录的内容中,获取所述类中的各个函数分别在应用程序中的函数起始地址。
4.根据权利要求3所述的方法,其特征在于,所述根据所述类的类信息的存储结构以及所述类的类信息的存储结构在应用程序中的类起始地址,在类信息字段中记录的内容中,确定所述类中包括的函数的数量,包括:
根据所述类的类信息的存储结构以及所述类的类信息的存储结构在应用程序中的类起始地址,在类信息字段中记录的内容中,确定所述类的类信息的存储结构中的数量字符串,数量字符串用于指示所述类中包括的函数的数量;
根据所述数量字符串确定所述类中包括的函数的数量。
5.根据权利要求3所述的方法,其特征在于,所述根据所述类的类信息的存储结构、所述类的类信息的存储结构在应用程序中的类起始地址以及所述数量,在类信息字段中记录的内容中,获取所述类中的各个函数分别在应用程序中的函数起始地址,包括:
根据所述类的类信息的存储结构、所述类的类信息的存储结构在应用程序中的类起始地址以及所述数量,在类信息字段中记录的内容中,分别确定所述类中的各个函数的地址字符串,函数的地址字符串用于指示函数在应用程序中的函数起始地址;
根据各个函数的地址字符串分别确定各个函数分别在应用程序中的函数起始地址。
6.根据权利要求2所述的方法,其特征在于,所述根据所述类中的各个函数分别在应用程序中的函数起始地址以及代码段中的函数指令段中记录的内容,获取所述类中的各个函数分别在应用程序中的函数地址区间,包括:
对于所述类中的任意一个函数,可以根据所述函数在应用程序中的函数起始地址以及代码段中的函数指令段中记录的内容,确定所述函数中包括的各个指令所占的空间大小;
根据所述函数在应用程序中的函数起始地址以及所述函数中包括的各个指令所占的空间大小,获取所述函数在应用程序中的函数结束地址;
根据所述函数起始地址以及所述函数结束地址获取所述函数在应用程序中的函数地址区间。
7.根据权利要求1所述的方法,其特征在于,所述根据应用程序中的代码段中的类地址字段中记录的内容,获取应用程序包括的类中的至少部分类的类信息的存储结构分别在应用程序中的类起始地址,包括:
获取类地址字段在应用程序中的段起始地址,以及,确定类地址字段的存储结构;
根据类地址字段的存储结构以及所述段起始地址,在类地址字段中记录的内容中,获取应用程序中的类中的至少部分类中的各个类的类信息的存储结构的偏移量,任意一个类的类信息的存储结构的偏移量包括:所述类的类信息的存储结构在应用程序中的类起始地址与位于所述类之前且与所述类相邻的类的存储结构在应用程序中的类起始地址之间的距离;
根据所述段起始地址以及至少部分类中的各个类的类信息的存储结构的偏移量,分别获取至少部分类中的各个类的类信息的存储结构在应用程序中的类起始地址。
8.一种数据处理装置,其特征在于,所述装置包括:
第一获取模块,用于在应用程序运行的过程中崩溃的情况下,获取崩溃相关的指令在应用程序中的指令起始地址;
第二获取模块,用于根据应用程序中的代码段中的类地址字段中记录的内容,获取应用程序包括的类中的至少部分类的类信息的存储结构分别在应用程序中的类起始地址;
确定模块,用于对于至少部分类中的任意一个类,确定在所述代码段中的类信息字段中的所述类的类信息的存储结构,第三获取模块,用于根据所述类的类信息的存储结构、所述类的类信息的存储结构在应用程序中的类起始地址以及类信息字段中记录的内容,获取所述类中的各个函数分别在应用程序中的函数地址区间;
筛选模块,用于在获取的函数地址区间中筛选崩溃相关的指令在应用程序中的指令起始地址所在的目标函数地址区间;
输出模块,用于根据所述目标函数地址区间输出所述崩溃相关的指令所属的函数的函数名。
9.根据权利要求8所述的装置,其特征在于,所述第三获取模块包括:
第一获取单元,用于根据所述类的类信息的存储结构以及所述类的类信息的存储结构在应用程序中的类起始地址,在类信息字段中记录的内容中,获取所述类中的各个函数分别在应用程序中的函数起始地址;
第二获取单元,用于根据所述类中的各个函数分别在应用程序中的函数起始地址以及代码段中的函数指令段中记录的内容,获取所述类中的各个函数分别在应用程序中的函数地址区间。
10.根据权利要求9所述的装置,其特征在于,所述第一获取单元包括:
第一确定子单元,用于根据所述类的类信息的存储结构以及所述类的类信息的存储结构在应用程序中的类起始地址,在类信息字段中记录的内容中,确定所述类中包括的函数的数量;
第一获取子单元,用于根据所述类的类信息的存储结构、所述类的类信息的存储结构在应用程序中的类起始地址以及所述数量,在类信息字段中记录的内容中,获取所述类中的各个函数分别在应用程序中的函数起始地址。
11.根据权利要求10所述的装置,其特征在于,所述第一确定子单元具体用于:根据所述类的类信息的存储结构以及所述类的类信息的存储结构在应用程序中的类起始地址,在类信息字段中记录的内容中,确定所述类的类信息的存储结构中的数量字符串,数量字符串用于指示所述类中包括的函数的数量;根据所述数量字符串确定所述类中包括的函数的数量。
12.根据权利要求10所述的装置,其特征在于,所述第一获取子单元具体用于:根据所述类的类信息的存储结构、所述类的类信息的存储结构在应用程序中的类起始地址以及所述数量,在类信息字段中记录的内容中,分别确定所述类中的各个函数的地址字符串,函数的地址字符串用于指示函数在应用程序中的函数起始地址;根据各个函数的地址字符串分别确定各个函数分别在应用程序中的函数起始地址。
13.根据权利要求9所述的装置,其特征在于,所述第二获取单元包括:
第二确定子单元,用于对于所述类中的任意一个函数,可以根据所述函数在应用程序中的函数起始地址以及代码段中的函数指令段中记录的内容,确定所述函数中包括的各个指令所占的空间大小;
第二获取子单元,用于根据所述函数在应用程序中的函数起始地址以及所述函数中包括的各个指令所占的空间大小,获取所述函数在应用程序中的函数结束地址;
第三获取子单元,用于根据所述函数起始地址以及所述函数结束地址获取所述函数在应用程序中的函数地址区间。
14.根据权利要求8所述的装置,其特征在于,所述第二获取模块包括:
第三获取单元,用于获取类地址字段在应用程序中的段起始地址,以及,确定单元,用于确定类地址字段的存储结构;
第四获取单元,用于根据类地址字段的存储结构以及所述段起始地址,在类地址字段中记录的内容中,获取应用程序中的类中的至少部分类中的各个类的类信息的存储结构的偏移量,任意一个类的类信息的存储结构的偏移量包括:所述类的类信息的存储结构在应用程序中的类起始地址与位于所述类之前且与所述类相邻的类的存储结构在应用程序中的类起始地址之间的距离;
第五获取单元,用于根据所述段起始地址以及至少部分类中的各个类的类信息的存储结构的偏移量,分别获取至少部分类中的各个类的类信息的存储结构在应用程序中的类起始地址。
15.一种电子设备,其特征在于,包括:处理器、存储器及存储在所述存储器上并可在所述处理器上运行的计算机程序,所述计算机程序被所述处理器执行时实现如权利要求1至7中任一项所述的数据处理方法的步骤。
16.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质上存储有计算机程序,所述计算机程序被处理器执行时实现如权利要求1至7中任一项所述的数据处理方法的步骤。
CN202111216763.6A 2021-10-19 2021-10-19 一种数据处理方法、装置、电子设备及存储介质 Active CN114020505B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202111216763.6A CN114020505B (zh) 2021-10-19 2021-10-19 一种数据处理方法、装置、电子设备及存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202111216763.6A CN114020505B (zh) 2021-10-19 2021-10-19 一种数据处理方法、装置、电子设备及存储介质

Publications (2)

Publication Number Publication Date
CN114020505A true CN114020505A (zh) 2022-02-08
CN114020505B CN114020505B (zh) 2022-12-23

Family

ID=80056627

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202111216763.6A Active CN114020505B (zh) 2021-10-19 2021-10-19 一种数据处理方法、装置、电子设备及存储介质

Country Status (1)

Country Link
CN (1) CN114020505B (zh)

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN107092554A (zh) * 2016-02-18 2017-08-25 阿里巴巴集团控股有限公司 一种应用程序的故障代码确认方法及装置
CN111090593A (zh) * 2020-03-25 2020-05-01 同盾控股有限公司 确定崩溃归属的方法、装置、电子设备及存储介质
CN111258803A (zh) * 2020-02-12 2020-06-09 北京字节跳动网络技术有限公司 崩溃定位方法、装置及电子设备
CN111381992A (zh) * 2020-03-06 2020-07-07 北京五八信息技术有限公司 一种崩溃日志处理方法、装置、电子设备及存储介质
CN112905378A (zh) * 2021-03-03 2021-06-04 广州虎牙科技有限公司 崩溃信息解析方法、装置、电子设备和可读存储介质

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN107092554A (zh) * 2016-02-18 2017-08-25 阿里巴巴集团控股有限公司 一种应用程序的故障代码确认方法及装置
CN111258803A (zh) * 2020-02-12 2020-06-09 北京字节跳动网络技术有限公司 崩溃定位方法、装置及电子设备
CN111381992A (zh) * 2020-03-06 2020-07-07 北京五八信息技术有限公司 一种崩溃日志处理方法、装置、电子设备及存储介质
CN111090593A (zh) * 2020-03-25 2020-05-01 同盾控股有限公司 确定崩溃归属的方法、装置、电子设备及存储介质
CN112905378A (zh) * 2021-03-03 2021-06-04 广州虎牙科技有限公司 崩溃信息解析方法、装置、电子设备和可读存储介质

Also Published As

Publication number Publication date
CN114020505B (zh) 2022-12-23

Similar Documents

Publication Publication Date Title
US20160226519A1 (en) Method and device for compressing firmware program, method and device for decompressing firmware program
CN111767006B (zh) 数据处理方法及装置
CN114020505B (zh) 一种数据处理方法、装置、电子设备及存储介质
CN106354595B (zh) 移动终端、硬件组件状态检测方法及装置
CN113590091A (zh) 一种数据处理方法、装置、电子设备及存储介质
CN110457084B (zh) 一种加载方法及装置
CN108549570B (zh) 用户界面的更新方法及装置
CN113946346B (zh) 一种数据处理方法、装置、电子设备及存储介质
CN113934452B (zh) 一种数据处理方法、装置、电子设备及存储介质
CN114020504B (zh) 一种数据处理方法、装置、电子设备及存储介质
CN114489641B (zh) 一种数据处理方法、装置、电子设备及存储介质
CN113806227B (zh) 一种信息处理方法、装置、电子设备及存储介质
CN114416085A (zh) 一种数据处理方法、装置、电子设备及存储介质
CN111767249B (zh) 确定函数自身运行时间的方法及装置
CN111241097B (zh) 处理对象的方法、处理对象的装置及存储介质
CN115794853B (zh) 政务数据资源目录的更新方法、装置、电子设备及介质
CN112182027B (zh) 信息查询方法、装置、电子设备及存储介质
CN115809054A (zh) 一种数据处理方法、装置、电子设备及存储介质
CN113849208A (zh) 应用程序管理方法及装置、电子设备和存储介质
CN113703858A (zh) 应用启动方法和装置
CN116483436A (zh) 一种数据处理方法、装置、电子设备及存储介质
CN115705219A (zh) 终端启动方法、装置、存储介质及终端
CN112825035A (zh) 一种程序安装文件的生成、处理方法及装置
CN114385687A (zh) 开关状态的操作方法及装置、电子设备和存储介质
CN113987247A (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