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

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

Info

Publication number
CN116483436A
CN116483436A CN202310293864.6A CN202310293864A CN116483436A CN 116483436 A CN116483436 A CN 116483436A CN 202310293864 A CN202310293864 A CN 202310293864A CN 116483436 A CN116483436 A CN 116483436A
Authority
CN
China
Prior art keywords
symbol
dynamic library
current dynamic
class
target
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.)
Pending
Application number
CN202310293864.6A
Other languages
English (en)
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.)
58tongcheng Information Technology Co ltd
Original Assignee
58tongcheng 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 58tongcheng Information Technology Co ltd filed Critical 58tongcheng Information Technology Co ltd
Priority to CN202310293864.6A priority Critical patent/CN116483436A/zh
Publication of CN116483436A publication Critical patent/CN116483436A/zh
Pending legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/70Software maintenance or management
    • G06F8/75Structural analysis for program understanding
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/36Preventing errors by testing or debugging software
    • G06F11/3604Software analysis for verifying properties of programs
    • G06F11/3608Software analysis for verifying properties of programs using formal methods, e.g. model checking, abstract interpretation
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02DCLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
    • Y02D10/00Energy efficient computing, e.g. low power processors, power management or thermal management

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Software Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Hardware Design (AREA)
  • Quality & Reliability (AREA)
  • Stored Programmes (AREA)

Abstract

本发明提供了一种数据处理方法、装置、电子设备及存储介质。获取目标项目对应的多个当前动态库中的各个当前动态库的可执行文件。对于任意一个当前动态库,在该当前动态库的可执行文件中获取该当前动态库的符号表,根据各个符号的类型,在符号表包括的符号中筛选目标符号。在各个当前动态库中的符号表中的目标符号中查找到相同的目标符号的情况下,确定存在符号冲突。通过本申请,在目标项目对应的动态库是编译后的文件的情况下,能够快速且准确检测目标项目对应的任意两个动态库中是否存在类的类名相同且相同的类名对应的类中的函数的函数名相同的情况。

Description

一种数据处理方法、装置、电子设备及存储介质
技术领域
本发明涉及计算机技术领域,尤其涉及一种数据处理方法、装置、电子设备及存储介质。
背景技术
随着技术的飞速发展,应用程序在人们的生活和工作中愈发重要,厂商为了更好地服务广大用户,往往会开发具有各种功能的应用程序。
例如,开发人员可以在集成开发工具中开发应用程序的计算机程序代码,并对开发的应用程序的计算机程序代码编译,得到应用程序的安装包,然后对外发布应用程序的安装包,以供广大用户下载应用程序的安装包,并基于应用程序的安装包在自己的设备中安装应用程序,进而可以使用应用程序。
发明内容
本申请示出了一种数据处理方法、装置、电子设备及存储介质。
第一方面,本申请示出了一种数据处理方法,所述方法应用于电子设备,所述方法包括:
获取目标项目对应的多个当前动态库中的各个当前动态库的可执行文件;
对于所述多个当前动态库中的任意一个所述当前动态库,在所述当前动态库的可执行文件中获取所述当前动态库的符号表,所述当前动态库中的符号表中包括至少一个符号以及各个符号的类型,符号包括至少由在所述当前动态库中使用到的函数的函数名以及所述使用到的函数所在的类的类名组成的字符串;根据各个符号的类型,在所述符号表包括的符号中筛选目标符号,所述目标符号中的类名对应的类是在所述当前动态库中定义的类,且所述目标符号中的函数名对应的函数是在所述当前动态库中定义的函数;
在所述多个当前动态库中的各个当前动态库中的符号表中的目标符号中查找相同的目标符号;
在各个当前动态库中的符号表中的目标符号中查找到相同的目标符号的情况下,确定存在符号冲突。
在一个可选的实现方式中,所述根据各个符号的类型,在所述符号表包括的符号中筛选目标符号,包括:
对于所述符号表中的任意一个符号,确定所述符号的类型是否为预设类型,所述预设类型至少包括:N_ABS(0x2)、N_SECT(0xe)、N_INDR(0xa)以及N_EXT(0x01);
在所述符号的类型为预设类型的情况下,确定所述符号为所述目标符号。
在一个可选的实现方式中,所述方法还包括:
在各个当前动态库中的符号表中的目标符号中查找到相同的目标符号的情况下,输出提示信息,所述提示信息用于提示所述多个当前动态库中存在包括的函数的函数名相同且函数所在的类的类名相同的情况;所述提示信息中包括:所述相同的目标符号各自所在符号表所属的当前动态库的库名以及所述相同的目标符号中的类名和函数名。
在一个可选的实现方式中,所述方法还包括:
对于存在符号冲突的任意一个当前动态库,向所述当前动态库的开发端发送修改提示信息,所述修改提示信息至少携带所述目标符号,所述修改提示信息用于提示修改所述当前动态库中出现的类名和/或出现的函数名,所述出现的类名包括所述目标符号中的类名,所述出现的函数名包括所述目标符号中的函数名;以使所述开发端获取所述当前动态库的当前源代码,查找所述当前源代码中所述出现的类名和/或所述出现的函数名,将所述当前源代码中的所述出现的类名修改为新类名和/或将所述当前源代码中的所述出现的函数名修改为新函数名,得到所述当前动态库的新源代码,对所述新源代码编译,得到所述当前动态库对应的新动态库,并向所述电子设备返回所述新动态库;
接收所述开发端返回的所述新动态库;
在所述目标项目对应的多个当前动态库中使用所述新动态库替换所述当前动态库。
在一个可选的实现方式中,所述方法还包括:
对于存在符号冲突的任意一个当前动态库,获取所述当前动态库的当前源代码;
查找所述当前源代码中出现的类名和/或出现的函数名,所述出现的类名包括所述目标符号中的类名,所述出现的函数名包括所述目标符号中的函数名;
将所述当前源代码中的所述出现的类名修改为新类名和/或将所述当前源代码中的所述出现的函数名修改为新函数名,得到所述当前动态库的新源代码;
对所述新源代码编译,得到所述当前动态库对应的新动态库;
在所述目标项目对应的多个当前动态库中使用所述新动态库替换所述当前动态库。
在一个可选的实现方式中,所述方法还包括:
获取所述目标项目对应的源代码;
查找所述目标项目对应的源代码中出现的类名和/或出现的函数名,所述出现的类名包括所述目标符号中的类名,所述出现的函数名包括所述目标符号中的函数名;
将所述目标项目对应的源代码中的所述出现的类名修改为新类名和/或将所述目标项目对应的源代码中的所述出现的函数名修改为新函数名,得到所述目标项目对应的新源代码。
在一个可选的实现方式中,所述方法还包括:
对所述目标项目对应的新源代码编译,得到所述目标项目对应的可执行文件。
第二方面,本申请示出了一种数据处理装置,所述装置应用于电子设备,所述装置包括:
第一获取模块,用于获取目标项目对应的多个当前动态库中的各个当前动态库的可执行文件;
第二获取模块,用于对于所述多个当前动态库中的任意一个所述当前动态库,在所述当前动态库的可执行文件中获取所述当前动态库的符号表,所述当前动态库中的符号表中包括至少一个符号以及各个符号的类型,符号包括至少由在所述当前动态库中使用到的函数的函数名以及所述使用到的函数所在的类的类名组成的字符串;筛选模块,用于根据各个符号的类型,在所述符号表包括的符号中筛选目标符号,所述目标符号中的类名对应的类是在所述当前动态库中定义的类,且所述目标符号中的函数名对应的函数是在所述当前动态库中定义的函数;
第一查找模块,用于在所述多个当前动态库中的各个当前动态库中的符号表中的目标符号中查找相同的目标符号;
确定模块,用于在各个当前动态库中的符号表中的目标符号中查找到相同的目标符号的情况下,确定存在符号冲突。
在一个可选的实现方式中,所述筛选模块包括:
第一确定单元,用于对于所述符号表中的任意一个符号,确定所述符号的类型是否为预设类型,所述预设类型至少包括:N_ABS(0x2)、N_SECT(0xe)、N_INDR(0xa)以及N_EXT(0x01);
第二确定单元,用于在所述符号的类型为预设类型的情况下,确定所述符号为所述目标符号。
在一个可选的实现方式中,所述装置还包括:
输出模块,用于在各个当前动态库中的符号表中的目标符号中查找到相同的目标符号的情况下,输出提示信息,所述提示信息用于提示所述多个当前动态库中存在包括的函数的函数名相同且函数所在的类的类名相同的情况;所述提示信息中包括:所述相同的目标符号各自所在符号表所属的当前动态库的库名以及所述相同的目标符号中的类名和函数名。
在一个可选的实现方式中,所述装置还包括:
发送模块,用于对于存在符号冲突的任意一个当前动态库,向所述当前动态库的开发端发送修改提示信息,所述修改提示信息至少携带所述目标符号,所述修改提示信息用于提示修改所述当前动态库中出现的类名和/或出现的函数名,所述出现的类名包括所述目标符号中的类名,所述出现的函数名包括所述目标符号中的函数名;以使所述开发端获取所述当前动态库的当前源代码,查找所述当前源代码中所述出现的类名和/或所述出现的函数名,将所述当前源代码中的所述出现的类名修改为新类名和/或将所述当前源代码中的所述出现的函数名修改为新函数名,得到所述当前动态库的新源代码,对所述新源代码编译,得到所述当前动态库对应的新动态库,并向所述电子设备返回所述新动态库;
接收模块,用于接收所述开发端返回的所述新动态库;
第一替换模块,用于在所述目标项目对应的多个当前动态库中使用所述新动态库替换所述当前动态库。
在一个可选的实现方式中,所述装置还包括:
第三获取模块,用于对于存在符号冲突的任意一个当前动态库,获取所述当前动态库的当前源代码;
第二查找模块,用于查找所述当前源代码中出现的类名和/或出现的函数名,所述出现的类名包括所述目标符号中的类名,所述出现的函数名包括所述目标符号中的函数名;
第一修改模块,用于将所述当前源代码中的所述出现的类名修改为新类名和/或将所述当前源代码中的所述出现的函数名修改为新函数名,得到所述当前动态库的新源代码;
第一编译模块,用于对所述新源代码编译,得到所述当前动态库对应的新动态库;
第二替换模块,用于在所述目标项目对应的多个当前动态库中使用所述新动态库替换所述当前动态库。
在一个可选的实现方式中,所述装置还包括:
第四获取模块,用于获取所述目标项目对应的源代码;
第三查找模块,用于查找所述目标项目对应的源代码中出现的类名和/或出现的函数名,所述出现的类名包括所述目标符号中的类名,所述出现的函数名包括所述目标符号中的函数名;
第二修改模块,用于将所述目标项目对应的源代码中的所述出现的类名修改为新类名和/或将所述目标项目对应的源代码中的所述出现的函数名修改为新函数名,得到所述目标项目对应的新源代码。
在一个可选的实现方式中,所述装置还包括:
第二编译模块,用于对所述目标项目对应的新源代码编译,得到所述目标项目对应的可执行文件。
第三方面,本申请示出了一种电子设备,所述电子设备包括:处理器;用于存储处理器可执行指令的存储器;其中,所述处理器被配置为执行如上述任一方面所述的方法。
第四方面,本申请示出了一种非临时性计算机可读存储介质,当所述存储介质中的指令由电子设备的处理器执行时,使得电子设备能够执行如上述任一方面所述的方法。
第五方面,本申请示出了一种计算机程序产品,当所述计算机程序产品中的指令由电子设备的处理器执行时,使得电子设备能够执行如上述任一方面所述的方法。
本申请提供的技术方案可以包括以下有益效果:
在本申请中,获取目标项目对应的多个当前动态库中的各个当前动态库的可执行文件。对于多个当前动态库中的任意一个当前动态库,在该当前动态库的可执行文件中获取该当前动态库的符号表,该当前动态库中的符号表中包括至少一个符号以及各个符号的类型,符号包括至少由在该当前动态库中使用到的函数的函数名以及使用到的函数所在的类的类名组成的字符串。根据各个符号的类型,在符号表包括的符号中筛选目标符号,目标符号中的类名对应的类是在该当前动态库中定义的类,且目标符号中的函数名对应的函数是在该当前动态库中定义的函数。在多个当前动态库中的各个当前动态库中的符号表中的目标符号中查找相同的目标符号。在各个当前动态库中的符号表中的目标符号中查找到相同的目标符号的情况下,确定存在符号冲突。通过本申请,在目标项目对应的动态库是编译后的文件的情况下,能够快速且准确检测目标项目对应的任意两个动态库中是否存在类的类名相同且相同的类名对应的类中的函数的函数名相同的情况。
另外,在本申请中,在当前动态库中使用到的类以及函数包括在当前动态库中定义的类以及定义的函数,以及,还包括,未在当前动态库中定义,而在其他动态库中定义,但是被当前动态库需要调用(或者使用)的类以及函数,例如,是需要被当前动态库中定义的一个类和/或函数调用的类以及函数等。
如此,在当前动态库中使用到的类以及函数可以划分为:在当前动态库中定义的类以及定义的函数,以及,未在当前动态库中定义的类以及函数。
其中,在一个当前动态库中调用其他动态库中的环节中不涉及终端所在的操作系统的调用机制,且仅仅涉及一个当前动态库,不涉及目标项目对应的其他当前动态库,进而不涉及在多个当前动态库中查找类以及函数。其次,对于在当前动态库中使用到的类以及函数中的未在当前动态库中定义的类以及函数而言,在当前动态库中仅仅存在未在当前动态库中定义的类的类名以及函数的函数名,不存在未在当前动态库中定义的类的具体内容(例如具体实现)以及函数的具体内容(例如具体实现)。
如此,在这种情况下,若需要确定多个当前动态库中是否存在包括的函数的函数名相同且函数所在的类的类名相同的情况,可以仅考虑调用当前动态库的环节,而可以不考虑在一个当前动态库中调用其他动态库中的环节,如此,可以不考虑未在当前动态库中定义的类以及函数,从而可以缩小确定范围,以及提高确定效率,且提高确定出的结果的有效性。
附图说明
图1是本申请的一种数据处理方法的步骤流程图。
图2是本申请的一种数据处理装置的结构框图。
图3是本申请的一种电子设备的框图。
图4是本申请的一种电子设备的框图。
具体实施方式
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
其中,在对外发布应用程序的安装包之后,收到了大量用户的反馈:很多用户在使用应用程序的过程中时不时就会出现异常情况,例如应用程序卡死、闪退或应用程序不执行用户的输入的指令等,导致用户无法正常使用应用程序,进而导致用户使用应用程序的使用体验差。
如此,提出了提高用户使用应用程序的使用体验的需求。
为了提高用户使用应用程序的使用体验,则可以尽可能地使得用户能够正常使用应用程序。
为了尽可能地使得用户能够正常使用应用程序,则可以尽可能地避免用户在使用应用程序的过程中出现上述异常情况。
为了尽可能地避免用户在使用应用程序的过程中出现上述异常情况,发明人对大量用户反馈的在使用应用程序的过程中时不时出现上述异常现象的情况进行了统计分析后发现:在使用应用程序的过程中出现上述异常现象的情况下,应用程序中往往加载有动态库。
动态库(Dynamic Libraries)也称作Shared Library、Shared Object或动态链接库等,动态库是多个Object Files封装起来的,但是动态库并不会在编译时直接置入应用程序中,而是将动态库的信息置入应用程序中,然后应用程序中在运行时再动态下载动态库并将动态库动态链接至应用程序中。
其次,发明人对应用程序的堆栈信息进行了统计分析,并发现:往往是在应用程序中调用动态库的情况下才出现上述异常情况。
进一步地,发明人又通过应用程序的堆栈信息对在应用程序中调用动态库的具体情况进行了统计分析,并发现:应用程序中有时候包括多个不同的动态库,各个动态库中分别包括至少一个类,各个类中分别包括至少一个函数,在需要在应用程序中调用某一个动态库中的某一个类中的某一个函数的情况下,并没有成功地在应用程序中调用该一个动态库中的该一个类中的该一个函数,而实际上在应用程序中调用到的是另一个动态库中的另一个类中的另一个函数,这就导致出现应用程序卡死、闪退或应用程序不执行用户的输入的指令等异常情况。
例如,“该一个动态库中的该一个类中的该一个函数的输入参数的数量和格式”与“实际调用到的另一个动态库中的另一个类中的另一个函数的输入参数的数量和格式”不同,导致应用程序无法根据实际调用到的另一个动态库中的另一个类中的另一个函数以及该一个动态库中的该一个类中的该一个函数的输入参数完成运算,导致出现应用程序卡死、闪退或应用程序不执行用户的输入的指令等异常情况。
进一步地,发明人又对“在需要在应用程序调用该一个动态库中的该一个类中的该一个函数的情况下,并没有成功地在应用程序中调用该一个动态库中的该一个类中的该一个函数,而实际上在应用程序中调用到的是另一个动态库中的另一个类中的另一个函数”的原因进行了分析,并发现:
在需要在应用程序调用的该一个动态库中的该一个类中的该一个函数与实际上在应用程序中调用到的另一个动态库中的另一个类中的另一个函数中,该一个类的类名与另一个类的类名相同,且该一个函数的函数名与另一个函数的函数名相同。
其次,在需要在应用程序调用该一个动态库中的该一个类中的该一个函数的情况下,虽然可能指明了需要调用该一个动态库中的该一个类中的该一个函数,例如指明了该一个动态库的库名、该一个类的类名以及该一个函数的函数名,但是,在应用程序开始运行时,应用程序中是没有动态库的,在需要的情况下应用程序可以动态地从应用程序的后台服务端中下载动态库并加载动态库。
在一个方式中,应用程序往往是请求应用程序所在的终端的操作系统加载动态库,例如,操作系统根据请求从应用程序的后台服务端中下载动态库,并在操作系统中加载动态库,以供应用程序调用。例如,在应用程序需要调用动态库的情况下,应用程序需要经由操作系统调用动态库。
但是,应用程序经由操作系统调用动态库的机制包括:在应用程序需要调用某一个动态库中的某一个类中的某一个函数的情况下,应用程序可以将该一个动态库的库名、该一个类的类名、该一个函数的函数名以及需要传递给该一个函数的输入参数传递给操作系统,之后操作系统可以根据该一个动态库的库名、该一个类的类名以及该一个函数的函数名调用该一个动态库中的该一个类中的该一个函数,并将需要传递给该一个函数的输入参数传递给该一个函数,以使该一个函数对需要传递给该一个函数的输入参数处理,得到处理结果,然后向应用程序返回处理结果,从而实现了对该动态库中的该函数的调用。
然而,发明人又发现,若操作系统中加载的动态库有很多,则操作系统调用动态库中的类中的函数时,往往是按照各个动态库加载至操作系统中的先后加载顺序,依次在各个动态库中根据类名以及函数名调用函数的,且在根据类名以及函数名调用函数调用到函数之后,就会停止继续调用,例如,只要在多个动态库中的其中一个动态库中调用到该一个类名所对应的类中的该一个函数名所对应的函数,就会认为调用到了函数,进而停止继续调用。
然而,在一个例子中,假设在操作系统中加载另一个动态库的时刻早于在操作系统中加载该一个动态库的时刻,则在根据该一个动态库的库名、该一个类的类名以及该一个函数的函数名调用函数的情况下,由于在操作系统中加载另一个动态库的时刻早于在操作系统中加载该一个动态库的时刻,如此,操作系统会先尝试根据该一个动态库的库名、该一个类的类名以及该一个函数的函数名在另一个动态库中调用函数,且由于在该一个动态库中的该一个类中的该一个函数与另一个动态库中的另一个类中的另一个函数中,该一个类的类名与另一个类的类名相同,且该一个函数的函数名与另一个函数的函数名相同。如此,操作系统在另一个动态库中能够调用到该一个类名所对应的类中的该一个函数名所对应的函数。之后就会停止调用操作,也即,不会再尝试在该一个动态库中调用函数,也就无法调用到该一个动态库中的该一个类中的该一个函数,如此导致实际调用到的另一个动态库中的另一个类中的另一个函数与需要调用的该一个动态库中的该一个类中的该一个函数不同。
鉴于此,发明人认为,若需要避免“若需要在经由操作系统调用该一个动态库中的该一个类中的该一个函数,但实际上经由操作系统调用到的是另一个动态库中的另一个类中的另一个函数”的情况发生,则需要使得经由操作系统调用到的是该一个动态库中的该一个类中的该一个函数。
但是应用程序经由操作系统调用动态库的上述机制是作为开发人员无法改变的。如此,发明人认为,如果在操作系统中加载的目标项目对应的任意两个动态库中不存在类的类名相同且相同的类名对应的类中的函数的函数名相同的情况,也即,在操作系统中加载的目标项目(例如包括应用程序等)对应的任意两个动态库中不存在一个动态库中的一个类的类名与另一个动态库中的另一个类的类名相同且该一个类中的函数的函数名与另一个类中的函数的函数名相同的情况,则就不会出现“若需要在经由操作系统调用该一个动态库中的该一个类中的该一个函数,但实际上经由操作系统调用到的是另一个动态库中的另一个类中的另一个函数”的情况。
例如,在上述例子中,若在该一个动态库中的任意一个类的类名与另一个动态库中的任意一个类的类名不同;或者,若该一个动态库中的其中一个类的类名与另一个动态库中的另一个类的类名相同,但是该其中一个类中的任意一个函数的函数名与该另一个类中的任意一个函数的函数名不同。则即使在操作系统中加载另一个动态库的时刻早于在操作系统中加载该一个动态库的时刻,则在根据该一个动态库的库名、该一个类的类名以及该一个函数的函数名调用函数的情况下,虽然由于在操作系统中加载另一个动态库的时刻早于在操作系统中加载该一个动态库的时刻,操作系统会先尝试根据该一个动态库的库名、该一个类的类名以及该一个函数的函数名在另一个动态库中调用函数,但是由于在该一个动态库中的任意一个类的类名与另一个动态库中的任意一个类的类名不同;或者,该一个动态库中的其中一个类的类名与另一个动态库中的另一个类的类名相同但是该其中一个类中的任意一个函数的函数名与该另一个类中的任意一个函数的函数名不同;如此,操作系统在另一个动态库中不会根据该一个类名以及该一个函数名调用到函数,例如,不会调用到该一个类名所对应的类中的该一个函数名所对应的函数,之后还会继续调用操作,例如,会再尝试在该一个动态库中调用函数,且在该一个动态库中能够调用到该一个类名所对应的类中的该一个函数名所对应的函数。如此使得实际调用到的函数就是需要调用的该一个动态库中的该一个类中的该一个函数。
进一步地,为了使得目标项目对应的任意两个动态库中不存在类的类名相同且相同的类名对应的类中的函数的函数名相同的情况,发明人想到了:可以检测目标项目对应的任意两个动态库中是否存在类的类名相同且相同的类名对应的类中的函数的函数名相同的情况,若目标项目对应的任意两个动态库中存在类的类名相同且相同的类名对应的类中的函数的函数名相同的情况,则可以消除目标项目对应的任意两个动态库中存在的类的类名相同且相同的类名对应的类中的函数的函数名相同的情况。
然而,发明人又发现,在开发人员开发应用程序的过程中,有些动态库是其他厂商开发的,开发人员是借助其他厂商已经开发好的动态库等,其他厂商已经开发好的动态库往往是编译后的文件,例如是二进制文件,开发人员是无法读懂二进制文件中内容的,进而无法快速确定出动态库中的各个类的类名以及各个类中的各个函数的函数名,很难快速且准确检测目标项目对应的任意两个动态库中是否存在类的类名相同且相同的类名对应的类中的函数的函数名相同的情况。
进一步地,发明人又发现,其他厂商已经开发好的动态库往往是编译后的文件,例如是mach-o格式的二进制文件等。
为此,为了在其他厂商已经开发好的动态库是编译后的文件的情况下,能够快速且准确检测目标项目对应的任意两个动态库中是否存在类的类名相同且相同的类名对应的类中的函数的函数名相同的情况,参照图1,示出了本申请的一种数据处理方法的步骤流程图,该方法应用于电子设备。
在本申请中,电子设备包括终端以及服务端等。
终端可以包括目标项目的开发人员使用的终端等,例如包括台式电脑或笔记本电脑等。
服务端可以包括目标项目所属的厂商的服务端等。
其中,该方法具体可以包括如下步骤:
在步骤S101中,获取目标项目对应的多个当前动态库中的各个当前动态库的可执行文件。
目标项目可以是开发应用程序的工程或者已经开发完毕的应用程序等。
当前动态库的可执行文件可以是对当前动态库的当前源代码编译得到的。
当前动态库可以是目标项目的开发人员开发的,也可以是目标项目所属的厂商中的其他开发人员(与目标项目的开发人员不同)开发的,也可以是非目标项目所属的厂商开发的(也即第三方开发的等)。
其中,当前动态库的当前源代码中包括至少一个类,每一个类中包括至少一个函数。类具有类名,函数具有函数名。
当前动态库的可执行文件可以包括mach-o格式的文件等,当然,也可以包括其他格式的文件,本申请对此不加以限定。
目标项目对应的多个当前动态库的可执行文件可能位于电子设备本地,也可能未位于电子设备本地,例如位于云端等。
在目标项目对应的多个当前动态库的可执行文件未位于电子设备本地的情况下,如果目标项目对应的计算机程序代码(源代码)中部署有目标项目对应的各个当前动态库的库名,则电子设备可以从目标项目对应的计算机程序代码(源代码)中获取目标项目对应的各个当前动态库的库名,或者,开发人员可以向电子设备输入目标项目对应的多个当前动态库中的各个当前动态库的库名,如此,电子设备可以接收开发人员输入的目标项目对应的多个当前动态库中的各个当前动态库的库名。然后可以根据目标项目对应的多个当前动态库中的各个当前动态库的库名从云端下载目标项目对应的多个当前动态库中的各个当前动态库的可执行文件。
或者,在目标项目对应的多个当前动态库的可执行文件位于电子设备本地的情况下,如果目标项目对应的计算机程序代码(源代码)中部署有目标项目对应的各个当前动态库的库名,则电子设备可以从目标项目对应的计算机程序代码(源代码)中获取目标项目对应的各个当前动态库的库名,或者,开发人员可以向电子设备输入目标项目对应的多个当前动态库中的各个当前动态库的库名,如此,电子设备可以接收开发人员输入的目标项目对应的多个当前动态库中的各个当前动态库的库名。然后可以根据目标项目对应的多个当前动态库中的各个当前动态库的库名电子设备中查找目标项目对应的多个当前动态库中的各个当前动态库的可执行文件。
在步骤S102中,对于多个当前动态库中的任意一个当前动态库,在该当前动态库的可执行文件中获取该当前动态库的符号表,该当前动态库中的符号表中包括至少一个符号以及各个符号的类型,符号包括至少由在该当前动态库中使用到的函数的函数名以及使用到的函数所在的类的类名组成的字符串。根据各个符号的类型,在符号表包括的符号中筛选目标符号,目标符号中的类名对应的类是在该当前动态库中定义的类,且目标符号中的函数名对应的函数是在该当前动态库中定义的函数。
对于多个当前动态库中的其他每一个当前动态库,同样执行上述操作。
对于多个当前动态库中的任意一个当前动态库,该当前动态库的可执行文件中往往包括有很多内容,例如包括符号表(symboltable)等,符号表中包括有包括至少一个符号(symbol)以及各个符号的类型,符号包括至少由在该当前动态库中使用到的函数的函数名以及使用到的函数所在的类的类名组成的字符串。
该当前动态库中的符号表中的符号的数量取决于在该当前动态库中使用到的各个类中的函数的数量等。例如,该当前动态库中的符号表中的符号的数量可以是在该当前动态库中使用到的各个类中的函数的总和等。
例如,假设在该当前动态库中使用到了类A、类B以及类C。
其中,“A”为类A的类名,“B”为类B的类名以及“C”为类C的类名。
类A中包括有函数1、函数2以及函数3。类B中包括有函数4、函数5以及函数6。类C中包括有函数7、函数8以及函数9。
其中,“1”为函数1的函数名,“2”为函数2的函数名,“3”为函数3的函数名,“4”为函数4的函数名,“5”为函数5的函数名,“6”为函数6的函数名,“7”为函数7的函数名,“8”为函数8的函数名,“9”为函数9的函数名。
则该当前动态库的符号表中的符号可以包括:“A.1”、“A.2”、“A.3”、“B.4”、“B.5”、“B.6”、“C.7”、“C.8”以及“C.9”等9个符号。
在本申请中,符号的类型包括:
N_UNDF(0x0):该类型说明该符号为未定义符号,未定义符号是在该当前动态库中被使用(例如应用等),但其是在其他动态库中定义的符号。
N_ABS(0x2):该类型说明该符号是绝对符号。
N_SECT(0xe):该类型说明该符号在n_sect中指定的段号中定义。
N_PBUD(0xc):该类型说明该符号为未定义符号,镜像使用符号的预绑定值。
N_INDR(0xa):该类型说明该符号定义为与另一个符号相同,并且Value字段是String Table中的索引,用于指定另一个符号的名称,链接该符号时,该符号和另一个符号都具有相同的定义类型和值。
N_EXT(0x01):该类型说明该符号为外部符号,在该当前动态库中的外部定义或该当前动态库中定义,可以在其他动态库中使用。
上述是对符号的类型的示例性举例,根据实际情况,符号还可能具有其他类型,本申请在此不做详述。
其中,在根据各个符号的类型,在符号表包括的符号中筛选目标符号时,对于符号表中的任意一个符号,可以确定该符号的类型是否为预设类型,预设类型至少包括:N_ABS(0x2)、N_SECT(0xe)、N_INDR(0xa)以及N_EXT(0x01)。在该符号的类型为预设类型的情况下,可以确定该符号为目标符号。对于符号表中的其他每一个符号,同样如此。
在一个例子中,在目标项目对应的可执行文件包括Mach-O文件的情况下,符号表可以包括LC_SYMTAB等。
在步骤S103中,在多个当前动态库中的各个当前动态库中的符号表中的目标符号中查找相同的目标符号。
在各个当前动态库中的符号表中的目标符号中查找到相同的目标符号的情况下,在步骤S104中,确定存在符号冲突。
也即,多个当前动态库中存在包括的函数的函数名相同且函数所在的类的类名相同的情况。
例如,至少两个当前动态库中均存在目标符号中的类名对应的类(无论类中的具体内容/具体实现是否相同,但是类的类名相同),且至少两个当前动态库中的各个当前动态库中的目标符号中的类名对应的类中均存在目标符号中的函数名对应的函数(无论函数中的具体内容/具体实现是否相同,但是函数的函数名相同)等。
在各个当前动态库中的符号表中的目标符号中未查找到相同的目标符号的情况下,在步骤S105中,确定不存在符号冲突。
也即,多个当前动态库中不存在包括的函数的函数名相同且函数所在的类的类名相同的情况。
例如,在目标项目对应的多个当前动态库中的任意两个当前动态库中,其中一个当前动态库中的任意一个类的类名与另一个当前动态库中的任意一个类的类名均不同。
或者,在目标项目对应多个当前动态库中的任意两个当前动态库中,其中一个当前动态库中的其中一些类的类名与另一个当前动态库中的另一些类的类名相同,但是对于相同的类名中的任意一个类名,其中一个当前动态库中的该类名对应的类中的任意一个函数的函数名与另一个当前动态库中的该类名对应的类中的任意一个函数的函数名均不同。
在本申请中,获取目标项目对应的多个当前动态库中的各个当前动态库的可执行文件。对于多个当前动态库中的任意一个当前动态库,在该当前动态库的可执行文件中获取该当前动态库的符号表,该当前动态库中的符号表中包括至少一个符号以及各个符号的类型,符号包括至少由在该当前动态库中使用到的函数的函数名以及使用到的函数所在的类的类名组成的字符串。根据各个符号的类型,在符号表包括的符号中筛选目标符号,目标符号中的类名对应的类是在该当前动态库中定义的类,且目标符号中的函数名对应的函数是在该当前动态库中定义的函数。在多个当前动态库中的各个当前动态库中的符号表中的目标符号中查找相同的目标符号。在各个当前动态库中的符号表中的目标符号中查找到相同的目标符号的情况下,确定存在符号冲突。通过本申请,在目标项目对应的动态库是编译后的文件的情况下,能够快速且准确检测目标项目对应的任意两个动态库中是否存在类的类名相同且相同的类名对应的类中的函数的函数名相同的情况。
另外,在本申请中,在当前动态库中使用到的类以及函数包括在当前动态库中定义的类以及定义的函数,以及,还包括,未在当前动态库中定义,而在其他动态库中定义,但是被当前动态库需要调用(或者使用)的类以及函数,例如,是需要被当前动态库中定义的一个类和/或函数调用的类以及函数等。
如此,在当前动态库中使用到的类以及函数可以划分为:在当前动态库中定义的类以及定义的函数,以及,未在当前动态库中定义的类以及函数。
其中,在一个当前动态库中调用其他动态库中的环节中不涉及终端所在的操作系统的调用机制,且仅仅涉及一个当前动态库,不涉及目标项目对应的其他当前动态库,进而不涉及在多个当前动态库中查找类以及函数。其次,对于在当前动态库中使用到的类以及函数中的未在当前动态库中定义的类以及函数而言,在当前动态库中仅仅存在未在当前动态库中定义的类的类名以及函数的函数名,不存在未在当前动态库中定义的类的具体内容(例如具体实现)以及函数的具体内容(例如具体实现)。
如此,在这种情况下,若需要确定多个当前动态库中是否存在包括的函数的函数名相同且函数所在的类的类名相同的情况,可以仅考虑调用当前动态库的环节,而可以不考虑在一个当前动态库中调用其他动态库中的环节,如此,可以不考虑未在当前动态库中定义的类以及函数,从而可以缩小确定范围,以及提高确定效率,且提高确定出的结果的有效性。
进一步地,在本申请另一实施例中,在各个当前动态库中的符号表中的目标符号中查找到相同的目标符号的情况下,可以输出提示信息,提示信息用于提示多个当前动态库中存在包括的函数的函数名相同且函数所在的类的类名相同的情况。提示信息中包括:相同的目标符号各自所在符号表所属的当前动态库的库名以及相同的目标符号中的类名和函数名。
例如,在一个实施例中,可以在电子设备的屏幕上显示提示信息。
或者,在另一个实施例中,可以使用电子设备的音响播放提示信息。
或者,在又一个实施例中,可以将提示信息通过邮件、短信或PUSH消息等任何可用方式发送给开发人员,以供开发人员查看提示信息等。
或者,在又一个实施例中,可以在电子设备中的预设文件中记录提示信息,以供开发人员之后在需要的时候在预设文件中可以查看提示信息。
进一步地,在本申请另一实施例中,在各个当前动态库中的符号表中的目标符号中未查找到相同的目标符号的情况下,可以输出另一提示信息,另一提示信息用于提示多个当前动态库中不存在包括的函数的函数名相同且函数所在的类的类名相同的情况。
例如,在一个实施例中,可以在电子设备的屏幕上显示另一提示信息。
或者,在另一个实施例中,可以使用电子设备的音响播放另一提示信息。
或者,在又一个实施例中,可以将另一提示信息通过邮件、短信或PUSH消息等任何可用方式发送给开发人员,以供开发人员查看另一提示信息等。
或者,在又一个实施例中,可以在电子设备中的预设文件中记录另一提示信息,以供开发人员之后在需要的时候在预设文件中可以查看另一提示信息。
在本申请中,在开发人员感知到提示信息之后,就可以获知多个当前动态库中存在包括的函数的函数名相同且函数所在的类的类名相同的情况,开发人员可以对此进行针对性处理。
例如,对于存在符号冲突的任意一个当前动态库,开发人员可以在该当前动态库的当前源代码中手动查找目标符号中的类名和/或函数名。并将该当前动态库的当前源代码中将查找到的类名手动修改为新类名和/或将查找到的函数名修改为新函数名,得到该当前动态库的新源代码,并控制电子设备对该当前动态库的新源代码编译,得到该当前动态库对应的新动态库,然后可以在目标项目对应的多个当前动态库中使用新动态库替换该当前动态库。
或者,对于存在符号冲突的任意一个当前动态库,开发人员指示该当前动态库的开发端(包括该当前动态库的开发者等)在该当前动态库的当前源代码中手动查找目标符号中的类名和/或函数名。并将该当前动态库的当前源代码中将查找到的类名手动修改为新类名和/或将查找到的函数名修改为新函数名,得到该当前动态库的新源代码,并控制电子设备对该当前动态库的新源代码编译,得到该当前动态库对应的新动态库,并向开发人员返回新动态库。如此,开发人员可以得到开发端返回的新动态库,然后可以在目标项目对应的多个当前动态库中使用新动态库替换该当前动态库。
其中,目标符号中的类名与新类名不同,目标符号中的函数名与新函数名不同。
然而,上述过程需要开发人员人工参与,人工成本高,如此,为了降低人工成本,在本申请另一实施例中,不需要人工参与,电子设备可以自行请求当前动态库的开发端实施上述过程。
例如,对于存在符号冲突的任意一个当前动态库,电子设备可以向该当前动态库的开发端发送修改提示信息,修改提示信息至少携带目标符号,修改提示信息用于提示修改该当前动态库中出现的类名和/或出现的函数名,出现的类名包括该目标符号中的类名,出现的函数名包括该目标符号中的函数名;以使该当前动态库的开发端获取该当前动态库的当前源代码,查找该当前动态库的当前源代码中出现的类名和/或出现的函数名,将该当前动态库的当前源代码中的出现的类名修改为新类名和/或将该当前动态库中的当前源代码中的出现的函数名修改为新函数名,得到该当前动态库的新源代码,对该当前动态库的新源代码编译,得到该当前动态库对应的新动态库,并向电子设备返回新动态库。电子设备可以接收开发端返回的新动态库,然后可以在目标项目对应的多个当前动态库中使用新动态库替换该当前动态库。
或者,在一个例子中,电子设备可以自行实施上述过程。例如,对于存在符号冲突的任意一个当前动态库,获取(事先在电子设备存储的或者事先在云端中存储的等)该当前动态库的当前源代码,查找该当前动态库的当前源代码中出现的类名和/或出现的函数名,出现的类名包括目标符号中的类名,出现的函数名包括目标符号中的函数名;将该当前动态库的当前源代码中的出现的类名修改为新类名和/或将该当前动态库中的当前源代码中的出现的函数名修改为新函数名,得到该当前动态库的新源代码;对该当前动态库的新源代码编译,得到该当前动态库对应的新动态库,然后在目标项目对应的多个当前动态库中使用新动态库替换该当前动态库。
在“目标项目对应的多个当前动态库中的除存在符号冲突以外的当前动态库以及至少两个新动态库”的范围内的任意两个动态库中,其中一个动态库中的任意一个类的类名与另一个动态库中的任意一个类的类名均不同。
或者,在“目标项目对应的多个当前动态库中的除存在符号冲突以外的当前动态库以及至少两个新动态库”的范围内的任意两个动态库中,其中一个动态库中的其中一些类的类名与另一个动态库中的另一些类的类名相同,但是对于相同的类名中的任意一个类名,其中一个动态库中的该类名对应的类中的任意一个函数的函数名与另一个动态库中的该类名对应的类中的任意一个函数的函数名均不同。
其中,对于目标项目对应的任意一个当前动态库,在目标项目对应的源代码中,有一些组件需要在该当前动态库中调用目标符号中的类名对应的类中的目标符号中的函数名对应的函数,因此,这些组件中会存在该动态库的库名、目标符号中的类名以及目标符号中的函数名。
但是,由于在前述实施例中,已经在当前动态库的当前源代码中将目标符号表中的类名修改为新类名和/或将目标符号中的函数名修改为新函数名,得到当前动态库的新源代码并对新源代码编译,得到当前动态库对应的新动态库,且在目标项目对应的多个当前动态库中使用新动态库替换当前动态库。
也即,实际上,新动态库中已经不存在某一个类的类名为目标符号中的类名的情况,或者,新动态库中存在某一个类的类名为目标符号中的类名,但是新动态库中的该一个类中不存在某一个函数的函数名为目标符号中的函数名的情况。
这些组件目前不具有新类名以及新函数名,如此,这些组件无法调用新动态库中的新类名对应的类中的新函数名对应的函数,如此,这些组件就无法使用新动态库中的新类名对应的类中的新函数名对应的函数的功能。
因此,为了使得这些组件就能够使用新动态库中的新类名对应的类中的新函数名对应的函数的功能,可以获取目标项目对应的源代码,查找目标项目对应的源代码中出现的类名和/或出现的函数名,出现的类名包括目标符号中的类名,出现的函数名包括目标符号中的函数名,将目标项目对应的源代码中的出现的类名修改为新类名和/或将目标项目对应的源代码中的出现的函数名修改为新函数名,得到目标项目对应的新源代码。这样,这些组件中就具有新类名以及新函数名,如此,这些组件就可以根据新动态库的库名、新类名以及新函数名调用新动态库中的新类名对应的类中的新函数名对应的函数,如此,这些组件就可以使用新动态库中的新类名对应的类中的新函数名对应的函数的功能。当前动态库的库名与当前动态库对应的新动态库的库名相同。
通过本实施例,在各个当前动态库中的符号表中的目标符号中查找到相同的目标符号的情况下,可以在目标项目对应的源代码中查找目标符号中的类名和/或函数名。在目标项目对应的源代码中将查找到的类名修改为新类名和/或将查找到的函数名修改为新函数名,得到目标项目对应的新源代码。不需要人工修改目标项目对应的源代码即可实现对目标项目对应的源代码中的相关类名以及函数名修改,提高了自动化程度,降低了人工成本。
进一步地,在得到目标项目对应的新源代码的情况下,电子设备可以对目标项目对应的新源代码编译(自动编译,可以没有人工参与),得到目标项目对应的可执行文件。如此,不需要人工编译目标项目对应的新源代码,提高了自动化程度,降低了人工成本。
需要说明的是,对于方法实施例,为了简单描述,故将其都表述为一系列的动作组合,但是本领域技术人员应该知悉,本申请并不受所描述的动作顺序的限制,因为依据本申请,某些步骤可以采用其他顺序或者同时进行。其次,本领域技术人员也应该知悉,说明书中所描述的实施例均属于可选实施例,所涉及的动作并不一定是本申请所必须的。
参照图2,示出了本申请的一种数据处理装置的结构框图,所述装置应用于电子设备,所述装置包括:
第一获取模块11,用于获取目标项目对应的多个当前动态库中的各个当前动态库的可执行文件;
第二获取模块12,用于对于所述多个当前动态库中的任意一个所述当前动态库,在所述当前动态库的可执行文件中获取所述当前动态库的符号表,所述当前动态库中的符号表中包括至少一个符号以及各个符号的类型,符号包括至少由在所述当前动态库中使用到的函数的函数名以及所述使用到的函数所在的类的类名组成的字符串;筛选模块13,用于根据各个符号的类型,在所述符号表包括的符号中筛选目标符号,所述目标符号中的类名对应的类是在所述当前动态库中定义的类,且所述目标符号中的函数名对应的函数是在所述当前动态库中定义的函数;
第一查找模块14,用于在所述多个当前动态库中的各个当前动态库中的符号表中的目标符号中查找相同的目标符号;
确定模块15,用于在各个当前动态库中的符号表中的目标符号中查找到相同的目标符号的情况下,确定存在符号冲突。
在一个可选的实现方式中,所述筛选模块包括:
第一确定单元,用于对于所述符号表中的任意一个符号,确定所述符号的类型是否为预设类型,所述预设类型至少包括:N_ABS(0x2)、N_SECT(0xe)、N_INDR(0xa)以及N_EXT(0x01);
第二确定单元,用于在所述符号的类型为预设类型的情况下,确定所述符号为所述目标符号。
在一个可选的实现方式中,所述装置还包括:
输出模块,用于在各个当前动态库中的符号表中的目标符号中查找到相同的目标符号的情况下,输出提示信息,所述提示信息用于提示所述多个当前动态库中存在包括的函数的函数名相同且函数所在的类的类名相同的情况;所述提示信息中包括:所述相同的目标符号各自所在符号表所属的当前动态库的库名以及所述相同的目标符号中的类名和函数名。
在一个可选的实现方式中,所述装置还包括:
发送模块,用于对于存在符号冲突的任意一个当前动态库,向所述当前动态库的开发端发送修改提示信息,所述修改提示信息至少携带所述目标符号,所述修改提示信息用于提示修改所述当前动态库中出现的类名和/或出现的函数名,所述出现的类名包括所述目标符号中的类名,所述出现的函数名包括所述目标符号中的函数名;以使所述开发端获取所述当前动态库的当前源代码,查找所述当前源代码中所述出现的类名和/或所述出现的函数名,将所述当前源代码中的所述出现的类名修改为新类名和/或将所述当前源代码中的所述出现的函数名修改为新函数名,得到所述当前动态库的新源代码,对所述新源代码编译,得到所述当前动态库对应的新动态库,并向所述电子设备返回所述新动态库;
接收模块,用于接收所述开发端返回的所述新动态库;
第一替换模块,用于在所述目标项目对应的多个当前动态库中使用所述新动态库替换所述当前动态库。
在一个可选的实现方式中,所述装置还包括:
第三获取模块,用于对于存在符号冲突的任意一个当前动态库,获取所述当前动态库的当前源代码;
第二查找模块,用于查找所述当前源代码中出现的类名和/或出现的函数名,所述出现的类名包括所述目标符号中的类名,所述出现的函数名包括所述目标符号中的函数名;
第一修改模块,用于将所述当前源代码中的所述出现的类名修改为新类名和/或将所述当前源代码中的所述出现的函数名修改为新函数名,得到所述当前动态库的新源代码;
第一编译模块,用于对所述新源代码编译,得到所述当前动态库对应的新动态库;
第二替换模块,用于在所述目标项目对应的多个当前动态库中使用所述新动态库替换所述当前动态库。
在一个可选的实现方式中,所述装置还包括:
第四获取模块,用于获取所述目标项目对应的源代码;
第三查找模块,用于查找所述目标项目对应的源代码中出现的类名和/或出现的函数名,所述出现的类名包括所述目标符号中的类名,所述出现的函数名包括所述目标符号中的函数名;
第二修改模块,用于将所述目标项目对应的源代码中的所述出现的类名修改为新类名和/或将所述目标项目对应的源代码中的所述出现的函数名修改为新函数名,得到所述目标项目对应的新源代码。
在一个可选的实现方式中,所述装置还包括:
第二编译模块,用于对所述目标项目对应的新源代码编译,得到所述目标项目对应的可执行文件。
在本申请中,获取目标项目对应的多个当前动态库中的各个当前动态库的可执行文件。对于多个当前动态库中的任意一个当前动态库,在该当前动态库的可执行文件中获取该当前动态库的符号表,该当前动态库中的符号表中包括至少一个符号以及各个符号的类型,符号包括至少由在该当前动态库中使用到的函数的函数名以及使用到的函数所在的类的类名组成的字符串。根据各个符号的类型,在符号表包括的符号中筛选目标符号,目标符号中的类名对应的类是在该当前动态库中定义的类,且目标符号中的函数名对应的函数是在该当前动态库中定义的函数。在多个当前动态库中的各个当前动态库中的符号表中的目标符号中查找相同的目标符号。在各个当前动态库中的符号表中的目标符号中查找到相同的目标符号的情况下,确定存在符号冲突。通过本申请,在目标项目对应的动态库是编译后的文件的情况下,能够快速且准确检测目标项目对应的任意两个动态库中是否存在类的类名相同且相同的类名对应的类中的函数的函数名相同的情况。
另外,在本申请中,在当前动态库中使用到的类以及函数包括在当前动态库中定义的类以及定义的函数,以及,还包括,未在当前动态库中定义,而在其他动态库中定义,但是被当前动态库需要调用(或者使用)的类以及函数,例如,是需要被当前动态库中定义的一个类和/或函数调用的类以及函数等。
如此,在当前动态库中使用到的类以及函数可以划分为:在当前动态库中定义的类以及定义的函数,以及,未在当前动态库中定义的类以及函数。
其中,在一个当前动态库中调用其他动态库中的环节中不涉及终端所在的操作系统的调用机制,且仅仅涉及一个当前动态库,不涉及目标项目对应的其他当前动态库,进而不涉及在多个当前动态库中查找类以及函数。其次,对于在当前动态库中使用到的类以及函数中的未在当前动态库中定义的类以及函数而言,在当前动态库中仅仅存在未在当前动态库中定义的类的类名以及函数的函数名,不存在未在当前动态库中定义的类的具体内容(例如具体实现)以及函数的具体内容(例如具体实现)。
如此,在这种情况下,若需要确定多个当前动态库中是否存在包括的函数的函数名相同且函数所在的类的类名相同的情况,可以仅考虑调用当前动态库的环节,而可以不考虑在一个当前动态库中调用其他动态库中的环节,如此,可以不考虑未在当前动态库中定义的类以及函数,从而可以缩小确定范围,以及提高确定效率,且提高确定出的结果的有效性。
对于装置实施例而言,由于其与方法实施例基本相似,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。
可选的,本发明实施例还提供了一种电子设备,包括:处理器,存储器,存储在存储器上并可在处理器上运行的计算机程序,该计算机程序被处理器执行时实现上述方法实施例的各个过程,且能达到相同的技术效果,为避免重复,这里不再赘述。
本发明实施例还提供了一种计算机可读存储介质,计算机可读存储介质上存储有计算机程序,计算机程序被处理器执行时实现上述方法实施例的各个过程,且能达到相同的技术效果,为避免重复,这里不再赘述。其中,所述的计算机可读存储介质,如只读存储器(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所述的方法,其特征在于,所述根据各个符号的类型,在所述符号表包括的符号中筛选目标符号,包括:
对于所述符号表中的任意一个符号,确定所述符号的类型是否为预设类型,所述预设类型至少包括:N_ABS(0x2)、N_SECT(0xe)、N_INDR(0xa)以及N_EXT(0x01);
在所述符号的类型为预设类型的情况下,确定所述符号为所述目标符号。
3.根据权利要求1所述的方法,其特征在于,所述方法还包括:
在各个当前动态库中的符号表中的目标符号中查找到相同的目标符号的情况下,输出提示信息,所述提示信息用于提示所述多个当前动态库中存在包括的函数的函数名相同且函数所在的类的类名相同的情况;
其中,所述提示信息中包括:所述相同的目标符号各自所在符号表所属的当前动态库的库名以及所述相同的目标符号中的类名和函数名。
4.根据权利要求1所述的方法,其特征在于,所述方法还包括:
对于存在符号冲突的任意一个当前动态库,向所述当前动态库的开发端发送修改提示信息,所述修改提示信息至少携带所述目标符号,所述修改提示信息用于提示修改所述当前动态库中出现的类名和/或出现的函数名,所述出现的类名包括所述目标符号中的类名,所述出现的函数名包括所述目标符号中的函数名;以使所述开发端获取所述当前动态库的当前源代码,查找所述当前源代码中所述出现的类名和/或所述出现的函数名,将所述当前源代码中的所述出现的类名修改为新类名和/或将所述当前源代码中的所述出现的函数名修改为新函数名,得到所述当前动态库的新源代码,对所述新源代码编译,得到所述当前动态库对应的新动态库,并向所述电子设备返回所述新动态库;
接收所述开发端返回的所述新动态库;
在所述目标项目对应的多个当前动态库中使用所述新动态库替换所述当前动态库。
5.根据权利要求1所述的方法,其特征在于,所述方法还包括:
对于存在符号冲突的任意一个当前动态库,获取所述当前动态库的当前源代码;
查找所述当前源代码中出现的类名和/或出现的函数名,所述出现的类名包括所述目标符号中的类名,所述出现的函数名包括所述目标符号中的函数名;
将所述当前源代码中的所述出现的类名修改为新类名和/或将所述当前源代码中的所述出现的函数名修改为新函数名,得到所述当前动态库的新源代码;
对所述新源代码编译,得到所述当前动态库对应的新动态库;
在所述目标项目对应的多个当前动态库中使用所述新动态库替换所述当前动态库。
6.根据权利要求4或5所述的方法,其特征在于,所述方法还包括:
获取所述目标项目对应的源代码;
查找所述目标项目对应的源代码中出现的类名和/或出现的函数名,所述出现的类名包括所述目标符号中的类名,所述出现的函数名包括所述目标符号中的函数名;
将所述目标项目对应的源代码中的所述出现的类名修改为新类名和/或将所述目标项目对应的源代码中的所述出现的函数名修改为新函数名,得到所述目标项目对应的新源代码。
7.根据权利要求6所述的方法,其特征在于,所述方法还包括:
对所述目标项目对应的新源代码编译,得到所述目标项目对应的可执行文件。
8.一种数据处理装置,其特征在于,所述装置应用于电子设备,所述装置包括:
第一获取模块,用于获取目标项目对应的多个当前动态库中的各个当前动态库的可执行文件;
第二获取模块,用于对于所述多个当前动态库中的任意一个所述当前动态库,在所述当前动态库的可执行文件中获取所述当前动态库的符号表,所述当前动态库中的符号表中包括至少一个符号以及各个符号的类型,符号包括至少由在所述当前动态库中使用到的函数的函数名以及所述使用到的函数所在的类的类名组成的字符串;筛选模块,用于根据各个符号的类型,在所述符号表包括的符号中筛选目标符号,所述目标符号中的类名对应的类是在所述当前动态库中定义的类,且所述目标符号中的函数名对应的函数是在所述当前动态库中定义的函数;
第一查找模块,用于在所述多个当前动态库中的各个当前动态库中的符号表中的目标符号中查找相同的目标符号;
确定模块,用于在各个当前动态库中的符号表中的目标符号中查找到相同的目标符号的情况下,确定存在符号冲突。
9.根据权利要求8所述的装置,其特征在于,所述筛选模块包括:
第一确定单元,用于对于所述符号表中的任意一个符号,确定所述符号的类型是否为预设类型,所述预设类型至少包括:N_ABS(0x2)、N_SECT(0xe)、N_INDR(0xa)以及N_EXT(0x01);
第二确定单元,用于在所述符号的类型为预设类型的情况下,确定所述符号为所述目标符号。
10.根据权利要求8所述的装置,其特征在于,所述装置还包括:
输出模块,用于在各个当前动态库中的符号表中的目标符号中查找到相同的目标符号的情况下,输出提示信息,所述提示信息用于提示所述多个当前动态库中存在包括的函数的函数名相同且函数所在的类的类名相同的情况;
其中,所述提示信息中包括:所述相同的目标符号各自所在符号表所属的当前动态库的库名以及所述相同的目标符号中的类名和函数名。
11.根据权利要求8所述的装置,其特征在于,所述装置还包括:
发送模块,用于对于存在符号冲突的任意一个当前动态库,向所述当前动态库的开发端发送修改提示信息,所述修改提示信息至少携带所述目标符号,所述修改提示信息用于提示修改所述当前动态库中出现的类名和/或出现的函数名,所述出现的类名包括所述目标符号中的类名,所述出现的函数名包括所述目标符号中的函数名;以使所述开发端获取所述当前动态库的当前源代码,查找所述当前源代码中所述出现的类名和/或所述出现的函数名,将所述当前源代码中的所述出现的类名修改为新类名和/或将所述当前源代码中的所述出现的函数名修改为新函数名,得到所述当前动态库的新源代码,对所述新源代码编译,得到所述当前动态库对应的新动态库,并向所述电子设备返回所述新动态库;
接收模块,用于接收所述开发端返回的所述新动态库;
第一替换模块,用于在所述目标项目对应的多个当前动态库中使用所述新动态库替换所述当前动态库。
12.根据权利要求8所述的装置,其特征在于,所述装置还包括:
第三获取模块,用于对于存在符号冲突的任意一个当前动态库,获取所述当前动态库的当前源代码;
第二查找模块,用于查找所述当前源代码中出现的类名和/或出现的函数名,所述出现的类名包括所述目标符号中的类名,所述出现的函数名包括所述目标符号中的函数名;
第一修改模块,用于将所述当前源代码中的所述出现的类名修改为新类名和/或将所述当前源代码中的所述出现的函数名修改为新函数名,得到所述当前动态库的新源代码;
第一编译模块,用于对所述新源代码编译,得到所述当前动态库对应的新动态库;
第二替换模块,用于在所述目标项目对应的多个当前动态库中使用所述新动态库替换所述当前动态库。
13.根据权利要求11或12所述的装置,其特征在于,所述装置还包括:
第四获取模块,用于获取所述目标项目对应的源代码;
第三查找模块,用于查找所述目标项目对应的源代码中出现的类名和/或出现的函数名,所述出现的类名包括所述目标符号中的类名,所述出现的函数名包括所述目标符号中的函数名;
第二修改模块,用于将所述目标项目对应的源代码中的所述出现的类名修改为新类名和/或将所述目标项目对应的源代码中的所述出现的函数名修改为新函数名,得到所述目标项目对应的新源代码。
14.根据权利要求13所述的装置,其特征在于,所述装置还包括:
第二编译模块,用于对所述目标项目对应的新源代码编译,得到所述目标项目对应的可执行文件。
15.一种电子设备,其特征在于,包括:处理器、存储器及存储在所述存储器上并可在所述处理器上运行的计算机程序,所述计算机程序被所述处理器执行时实现如权利要求1至7中任一项所述的方法。
16.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质上存储有计算机程序,所述计算机程序被处理器执行时实现如权利要求1至7中任一项所述的方法的。
CN202310293864.6A 2023-03-23 2023-03-23 一种数据处理方法、装置、电子设备及存储介质 Pending CN116483436A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202310293864.6A CN116483436A (zh) 2023-03-23 2023-03-23 一种数据处理方法、装置、电子设备及存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202310293864.6A CN116483436A (zh) 2023-03-23 2023-03-23 一种数据处理方法、装置、电子设备及存储介质

Publications (1)

Publication Number Publication Date
CN116483436A true CN116483436A (zh) 2023-07-25

Family

ID=87224183

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202310293864.6A Pending CN116483436A (zh) 2023-03-23 2023-03-23 一种数据处理方法、装置、电子设备及存储介质

Country Status (1)

Country Link
CN (1) CN116483436A (zh)

Similar Documents

Publication Publication Date Title
CN109032606B (zh) 原生应用程序的编译处理方法、装置及终端
EP3428790B1 (en) Method and device for displaying application interface
CN107463372B (zh) 一种数据驱动的页面更新方法和装置
CN106293683B (zh) 一种项目的编译方法及装置
CN114528037B (zh) 一种应用启动方法、装置、电子设备及存储介质
CN115357277A (zh) 热更新方法、装置、电子设备、存储介质及程序产品
CN110457084B (zh) 一种加载方法及装置
CN114416247A (zh) 一种数据处理方法、装置、电子设备及存储介质
CN116483436A (zh) 一种数据处理方法、装置、电子设备及存储介质
CN108427568B (zh) 用户界面的更新方法及装置
CN113590091A (zh) 一种数据处理方法、装置、电子设备及存储介质
CN108549570B (zh) 用户界面的更新方法及装置
CN107463414B (zh) 应用安装方法及装置
CN111597106A (zh) 一种埋点管理方法及装置
CN113934452B (zh) 一种数据处理方法、装置、电子设备及存储介质
CN116126320B (zh) 一种数据处理方法、装置、电子设备及存储介质
CN113946346B (zh) 一种数据处理方法、装置、电子设备及存储介质
CN114020504B (zh) 一种数据处理方法、装置、电子设备及存储介质
CN114489641B (zh) 一种数据处理方法、装置、电子设备及存储介质
CN111625251B (zh) 一种处理应用实例的方法及装置
CN111596949B (zh) 一种开发应用程序的方法及装置
CN114020505B (zh) 一种数据处理方法、装置、电子设备及存储介质
CN114416084B (zh) 一种数据处理方法、装置、电子设备及存储介质
CN110659081B (zh) 用于程序对象的文件处理方法、装置及电子设备
CN116450210A (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