CN112947987A - 具有多个版本的共享库的处理方法和装置 - Google Patents
具有多个版本的共享库的处理方法和装置 Download PDFInfo
- Publication number
- CN112947987A CN112947987A CN202110124671.9A CN202110124671A CN112947987A CN 112947987 A CN112947987 A CN 112947987A CN 202110124671 A CN202110124671 A CN 202110124671A CN 112947987 A CN112947987 A CN 112947987A
- Authority
- CN
- China
- Prior art keywords
- symbol
- shared library
- replacement
- target
- version
- 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
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/70—Software maintenance or management
- G06F8/71—Version control; Configuration management
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/40—Transformation of program code
- G06F8/41—Compilation
Landscapes
- Engineering & Computer Science (AREA)
- General Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Software Systems (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Computer Security & Cryptography (AREA)
- Stored Programmes (AREA)
Abstract
本申请涉及一种具有多个版本的共享库的处理方法和装置,该方法包括:在可执行文件同时链接第一共享库的多个版本时,对第一共享库的每个版本执行:步骤S1,获取目标版本共享库对应的目标符号替换表,目标版本共享库为第一共享库的其中一个版本,目标符号替换表存储有目标版本共享库的原始符号及其相对应的替换符号;步骤S2,对目标版本共享库中的原始符号进行符号替换,生成包含替换符号的目标版本共享库。通过本申请,解决了相关技术中当不同版本、且不兼容的共享库被同一个程序的不同模块所依赖时,最终会出现符号冲突的问题,实现了在不修改程序源码的情况下,让共享库的多个版本能够和平地共存。
Description
技术领域
本申请涉及计算机领域,特别是涉及具有多个版本的共享库的处理方法、装置、计算机设备和计算机可读存储介质。
背景技术
Linux平台有动态库(也称为共享库)和静态库这两种不同形态的程序库。静态库是一些代码和数据的结合,在编译期间会被链接到程序当中。共享库则可作为独立的实体存在,在程序启动的时候被加载,可被不同的程序所共享。
当不同版本、且不兼容的共享库被同一个程序的不同模块所依赖时,最终会出现符号冲突的情况。
如图1所示,可执行文件a.out动态链接了共享库libB.so(简称为B)和共享库libC.so(简称为C),B和C又分别依赖共享库D的两个版本D_v1和D_v2。
由于D_v1和D_v2是同一个共享库的两个版本,它们的大多数符号都是相同的。为了避免运行时的符号冲突,现有的技术提供了以下两种解决方案:
方案1:如图2所示,将共享库D做成静态库,共享库libB.so和libC.so分别静态链接共享库D的不同版本libD_v1.a和libD_v2.a,并将共享库D中的符号对外隐藏。
方案2:如图3所示,共享库libB.so和libC.so不是直接动态链接共享库D的两个版本,而是采用动态加载(dlopen)的方式来分别使用共享库libD_v1.so和libD_v2.so。
针对上述两种方案,存在以下缺陷:
方案1所采用的静态链接的方式,生成的可执行文件体积较大,包含相同的公共代码,造成浪费,不同的程序无法共享完全相同的代码。
方案2所采用的动态加载(dlopen)的方式,需要结合dlsym动态查找共享库D中的符号。并且将动态链接修改为动态加载,需要修改外部调用模块(如图3中的共享库libB.so和libC.so)的源码。当外部使用的共享库D中的符号太多时,会显著增加编码复杂度,并且影响程序的执行效率。
目前针对相关技术中当不同版本、且不兼容的共享库被同一个程序的不同模块所依赖时,最终会出现符号冲突的情况,尚未提出有效的解决方案。
发明内容
本申请实施例提供了一种具有多个版本的共享库的处理方法、装置、计算机设备和计算机可读存储介质,以至少解决相关技术中当不同版本、且不兼容的共享库被同一个程序的不同模块所依赖时,最终会出现符号冲突的问题。
第一方面,本申请实施例提供了一种具有多个版本的共享库的处理方法,包括:
在可执行文件同时链接第一共享库的多个版本时,对所述第一共享库的每个版本执行以下步骤:
步骤S1,获取目标版本共享库对应的目标符号替换表,其中,所述目标版本共享库为所述第一共享库的其中一个版本,所述目标符号替换表存储有所述目标版本共享库的原始符号、以及与所述原始符号相对应的替换符号,所述替换符号为在所述原始符号的基础上添加用于指示所述目标版本共享库的版本的标识后所得到的符号;
步骤S2,根据所述目标符号替换表,对所述目标版本共享库中的所述原始符号进行符号替换,生成包含所述替换符号的目标版本共享库。
在其中一些实施例中,步骤S1,获取目标版本共享库对应的目标符号替换表包括:
步骤S11,获取所述目标版本共享库中的所述原始符号;
步骤S12,将所述原始符号添加所述用于指示所述目标版本共享库的版本的标识,得到所述替换符号;
步骤S13,建立所述原始符号与所述替换符号之间的对应关系;
步骤S14,将所述原始符号与所述替换符号对应存储在所述目标符号替换表中。
在其中一些实施例中,步骤S2,根据所述目标符号替换表,对所述目标版本共享库中的所述原始符号进行符号替换,生成包含所述替换符号的目标版本共享库包括:
步骤S21,将所述目标版本共享库的源码文件进行编译后得到的第一文件中的所述原始符号替换为所述替换符号,得到进行符号替换后的第一文件;
步骤S22,将所述进行符号替换后的第一文件经链接器进行链接后,生成所述包含所述替换符号的目标版本共享库。
在其中一些实施例中,在所述可执行文件同时链接多个共享库、且所述多个共享库中的每个共享库链接所述第一共享库的其中一个版本时,在对所述第一共享库的每个版本执行步骤S1和步骤S2之后,所述方法还包括:
对所述多个共享库中的每个共享库执行以下步骤:
步骤S3,根据所述目标符号替换表,对第二共享库中的所述原始符号进行符号替换,生成包含所述替换符号的第二共享库,其中,所述第二共享库为所述多个共享库中的其中一个,所述第二共享库链接所述目标版本共享库。
在其中一些实施例中,步骤S3,根据所述目标符号替换表,对第二共享库中的所述原始符号进行符号替换,生成包含所述替换符号的第二共享库包括:
步骤S31,将所述第二共享库的源码文件进行编译后得到的第二文件中的所述原始符号替换为所述替换符号,得到进行符号替换后的第二文件;
步骤S32,将所述进行符号替换后的第二文件经链接器进行链接后,生成所述包含所述替换符号的第二共享库。
第二方面,本申请实施例提供了一种具有多个版本的共享库的处理装置,包括:
执行单元,用于在可执行文件同时链接第一共享库的多个版本时,对所述第一共享库的每个版本执行以下步骤:
步骤S1,获取目标版本共享库对应的目标符号替换表,其中,所述目标版本共享库为所述第一共享库的其中一个版本,所述目标符号替换表存储有所述目标版本共享库的原始符号、以及与所述原始符号相对应的替换符号,所述替换符号为在所述原始符号的基础上添加用于指示所述目标版本共享库的版本的标识后所得到的符号;
步骤S2,根据所述目标符号替换表,对所述目标版本共享库中的所述原始符号进行符号替换,生成包含所述替换符号的目标版本共享库。
在其中一些实施例中,步骤S1,获取目标版本共享库对应的目标符号替换表包括:
步骤S11,获取所述目标版本共享库中的所述原始符号;
步骤S12,将所述原始符号添加所述用于指示所述目标版本共享库的版本的标识,得到所述替换符号;
步骤S13,建立所述原始符号与所述替换符号之间的对应关系;
步骤S14,将所述原始符号与所述替换符号对应存储在所述目标符号替换表中。
在其中一些实施例中,步骤S2,根据所述目标符号替换表,对所述目标版本共享库中的所述原始符号进行符号替换,生成包含所述替换符号的目标版本共享库包括:
步骤S21,将所述目标版本共享库的源码文件进行编译后得到的第一文件中的所述原始符号替换为所述替换符号,得到进行符号替换后的第一文件;
步骤S22,将所述进行符号替换后的第一文件经链接器进行链接后,生成所述包含所述替换符号的目标版本共享库。
第三方面,本申请实施例提供了一种计算机设备,包括存储器、处理器以及存储在所述存储器上并可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现如上述第一方面所述的具有多个版本的共享库的处理方法。
第四方面,本申请实施例提供了一种计算机可读存储介质,其上存储有计算机程序,该程序被处理器执行时实现如上述第一方面所述的具有多个版本的共享库的处理方法。
相比于相关技术,本申请实施例提供的具有多个版本的共享库的处理方法和装置,通过在可执行文件同时链接第一共享库的多个版本时,对所述第一共享库的每个版本执行以下步骤:步骤S1,获取目标版本共享库对应的目标符号替换表,其中,所述目标版本共享库为所述第一共享库的其中一个版本,所述目标符号替换表存储有所述目标版本共享库的原始符号、以及与所述原始符号相对应的替换符号,所述替换符号为在所述原始符号的基础上添加用于指示所述目标版本共享库的版本的标识后所得到的符号;步骤S2,根据所述目标符号替换表,对所述目标版本共享库中的所述原始符号进行符号替换,生成包含所述替换符号的目标版本共享库,解决了相关技术中当不同版本、且不兼容的共享库被同一个程序的不同模块所依赖时,最终会出现符号冲突的问题,实现了通过在编译期间将共享库编译后的文件中的符号重命名的方式,能够很好地解决符号冲突问题,在不修改程序源码的情况下,让共享库的多个版本能够和平地共存。
本申请的一个或多个实施例的细节在以下附图和描述中提出,以使本申请的其他特征、目的和优点更加简明易懂。
附图说明
此处所说明的附图用来提供对本申请的进一步理解,构成本申请的一部分,本申请的示意性实施例及其说明用于解释本申请,并不构成对本申请的不当限定。在附图中:
图1是根据相关技术的同一个程序的不同模块依赖不同版本的共享库的示意图;
图2是根据相关技术的静态链接方式的示意图;
图3是根据相关技术的动态加载方式的示意图;
图4是根据本申请实施例的移动终端的结构框图;
图5是根据本申请实施例的具有多个版本的共享库的处理方法的流程图;
图6是根据本申请实施例的可执行文件同时链接共享库的不同版本的示意图;
图7是根据本申请实施例的可执行文件链接的共享库在链接共享库的不同版本的示意图;
图8是根据本申请实施例的共享库多个版本共存的处理方法的流程图;
图9是根据现有技术的共享库正常构建过程的示意图;
图10是根据本申请实施例的改进的共享库构建过程的示意图;
图11是根据本申请实施例的具有多个版本的共享库的处理装置的示意图;
图12为根据本申请实施例的计算机设备的硬件结构示意图。
具体实施方式
为了使本申请的目的、技术方案及优点更加清楚明白,以下结合附图及实施例,对本申请进行描述和说明。应当理解,此处所描述的具体实施例仅仅用以解释本申请,并不用于限定本申请。基于本申请提供的实施例,本领域普通技术人员在没有作出创造性劳动的前提下所获得的所有其他实施例,都属于本申请保护的范围。
显而易见地,下面描述中的附图仅仅是本申请的一些示例或实施例,对于本领域的普通技术人员而言,在不付出创造性劳动的前提下,还可以根据这些附图将本申请应用于其他类似情景。此外,还可以理解的是,虽然这种开发过程中所作出的努力可能是复杂并且冗长的,然而对于与本申请公开的内容相关的本领域的普通技术人员而言,在本申请揭露的技术内容的基础上进行的一些设计,制造或者生产等变更只是常规的技术手段,不应当理解为本申请公开的内容不充分。
在本申请中提及“实施例”意味着,结合实施例描述的特定特征、结构或特性可以包含在本申请的至少一个实施例中。在说明书中的各个位置出现该短语并不一定均是指相同的实施例,也不是与其它实施例互斥的独立的或备选的实施例。本领域普通技术人员显式地和隐式地理解的是,本申请所描述的实施例在不冲突的情况下,可以与其它实施例相结合。
除非另作定义,本申请所涉及的技术术语或者科学术语应当为本申请所属技术领域内具有一般技能的人士所理解的通常意义。本申请所涉及的“一”、“一个”、“一种”、“该”等类似词语并不表示数量限制,可表示单数或复数。本申请所涉及的术语“包括”、“包含”、“具有”以及它们任何变形,意图在于覆盖不排他的包含;例如包含了一系列步骤或模块(单元)的过程、方法、系统、产品或设备没有限定于已列出的步骤或单元,而是可以还包括没有列出的步骤或单元,或可以还包括对于这些过程、方法、产品或设备固有的其它步骤或单元。本申请所涉及的“连接”、“相连”、“耦接”等类似的词语并非限定于物理的或者机械的连接,而是可以包括电气的连接,不管是直接的还是间接的。本申请所涉及的“多个”是指两个或两个以上。“和/或”描述关联对象的关联关系,表示可以存在三种关系,例如,“A和/或B”可以表示:单独存在A,同时存在A和B,单独存在B这三种情况。字符“/”一般表示前后关联对象是一种“或”的关系。本申请所涉及的术语“第一”、“第二”、“第三”等仅仅是区别类似的对象,不代表针对对象的特定排序。
本实施例提供了一种移动终端。图4是根据本申请实施例的移动终端的结构框图。如图4所示,该移动终端包括:射频(Radio Frequency,简称为RF)电路410、存储器420、输入单元430、显示单元440、传感器450、音频电路460、无线保真(wireless fidelity,简称为WiFi)模块470、处理器480、以及电源490等部件。本领域技术人员可以理解,图4中示出的移动终端结构并不构成对移动终端的限定,可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件布置。
下面结合图4对移动终端的各个构成部件进行具体的介绍:
RF电路410可用于收发信息或通话过程中,信号的接收和发送,特别地,将基站的下行信息接收后,给处理器480处理;另外,将设计上行的数据发送给基站。通常,RF电路包括但不限于天线、至少一个放大器、收发信机、耦合器、低噪声放大器(LowNoiseAmplifier,简称为LNA)、双工器等。此外,RF电路410还可以通过无线通信与网络和其他设备通信。上述无线通信可以使用任一通信标准或协议,包括但不限于全球移动通讯系统(Global System ofMobile communication,简称为GSM)、通用分组无线服务(GeneralPacket Radio Service,简称为GPRS)、码分多址(Code Division MultipleAccess,简称为CDMA)、宽带码分多址(Wideband Code Division MultipleAccess,简称为WCDMA)、长期演进(Long Term Evolution,简称为LTE)、电子邮件、短消息服务(Short MessagingService,简称为SMS)等。
存储器420可用于存储软件程序以及模块,处理器480通过运行存储在存储器420的软件程序以及模块,从而执行移动终端的各种功能应用以及数据处理。存储器420可主要包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需的应用程序(比如声音播放功能、图像播放功能等)等;存储数据区可存储根据移动终端的使用所创建的数据(比如音频数据、电话本等)等。此外,存储器420可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件、闪存器件、或其他易失性固态存储器件。
输入单元430可用于接收输入的数字或字符信息,以及产生与移动终端的用户设置以及功能控制有关的键信号输入。具体地,输入单元430可包括触控面板431以及其他输入设备432。触控面板431,也称为触摸屏,可收集用户在其上或附近的触摸操作(比如用户使用手指、触笔等任何适合的物体或附件在触控面板431上或在触控面板431附近的操作),并根据预先设定的程式驱动相应的连接装置。可选的,触控面板431可包括触摸检测装置和触摸控制器两个部分。其中,触摸检测装置检测用户的触摸方位,并检测触摸操作带来的信号,将信号传送给触摸控制器;触摸控制器从触摸检测装置上接收触摸信息,并将它转换成触点坐标,再送给处理器480,并能接收处理器480发来的命令并加以执行。此外,可以采用电阻式、电容式、红外线以及表面声波等多种类型实现触控面板431。除了触控面板431,输入单元430还可以包括其他输入设备432。具体地,其他输入设备432可以包括但不限于物理键盘、功能键(比如音量控制按键、开关按键等)、轨迹球、鼠标、操作杆等中的一种或多种。
显示单元440可用于显示由用户输入的信息或提供给用户的信息以及移动终端的各种菜单。显示单元440可包括显示面板441,可选的,可以采用液晶显示器(LiquidCrystal Display,简称为LCD)、有机发光二极管(Organic Light-Emitting Diode,简称为OLED)等形式来配置显示面板441。进一步的,触控面板431可覆盖显示面板441,当触控面板431检测到在其上或附近的触摸操作后,传送给处理器480以确定触摸事件的类型,随后处理器480根据触摸事件的类型在显示面板441上提供相应的视觉输出。虽然在图4中,触控面板431与显示面板441是作为两个独立的部件来实现移动终端的输入和输入功能,但是在某些实施例中,可以将触控面板431与显示面板441集成而实现移动终端的输入和输出功能。
移动终端还可包括至少一种传感器450,比如光传感器、运动传感器以及其他传感器。具体地,光传感器可包括环境光传感器及接近传感器,其中,环境光传感器可根据环境光线的明暗来调节显示面板441的亮度,接近传感器可在移动终端移动到耳边时,关闭显示面板441和/或背光。作为运动传感器的一种,加速计传感器可检测各个方向上(一般为三轴)加速度的大小,静止时可检测出重力的大小及方向,可用于识别移动终端姿态的应用(比如横竖屏切换、相关游戏、磁力计姿态校准)、振动识别相关功能(比如计步器、敲击)等;至于移动终端还可配置的陀螺仪、气压计、湿度计、温度计、红外线传感器等其他传感器,在此不再赘述。
音频电路460中的扬声器461,传声器462可提供用户与移动终端之间的音频接口。音频电路460可将接收到的音频数据转换后的电信号,传输到扬声器461,由扬声器461转换为声音信号输出;另一方面,传声器462将收集的声音信号转换为电信号,由音频电路460接收后转换为音频数据,再将音频数据输出处理器480处理后,经RF电路410以发送给比如另一移动终端,或者将音频数据输出至存储器420以便进一步处理。
WiFi属于短距离无线传输技术,移动终端通过WiFi模块470可以帮助用户收发电子邮件、浏览网页和访问流式媒体等,它为用户提供了无线的宽带互联网访问。虽然图4示出了WiFi模块470,但是可以理解的是,其并不属于移动终端的必须构成,完全可以根据需要在不改变发明的本质的范围内而省略,或者替换为其他的短距离无线传输模块,例如Zigbee模块、或者WAPI模块等。
处理器480是移动终端的控制中心,利用各种接口和线路连接整个移动终端的各个部分,通过运行或执行存储在存储器420内的软件程序和/或模块,以及调用存储在存储器420内的数据,执行移动终端的各种功能和处理数据,从而对移动终端进行整体监控。可选的,处理器480可包括一个或多个处理单元;优选的,处理器480可集成应用处理器和调制解调处理器,其中,应用处理器主要处理操作系统、用户界面和应用程序等,调制解调处理器主要处理无线通信。可以理解的是,上述调制解调处理器也可以不集成到处理器480中。
移动终端还包括给各个部件供电的电源490(比如电池),优选的,电源可以通过电源管理系统与处理器480逻辑相连,从而通过电源管理系统实现管理充电、放电、以及功耗管理等功能。
尽管未示出,移动终端还可以包括摄像头、蓝牙模块等,在此不再赘述。
在本实施例中,处理器480被配置为:在可执行文件同时链接第一共享库的多个版本时,对所述第一共享库的每个版本执行以下步骤:步骤S1,获取目标版本共享库对应的目标符号替换表,其中,所述目标版本共享库为所述第一共享库的其中一个版本,所述目标符号替换表存储有所述目标版本共享库的原始符号、以及与所述原始符号相对应的替换符号,所述替换符号为在所述原始符号的基础上添加用于指示所述目标版本共享库的版本的标识后所得到的符号;步骤S2,根据所述目标符号替换表,对所述目标版本共享库中的所述原始符号进行符号替换,生成包含所述替换符号的目标版本共享库。
在其中一些实施例中,处理器480还被配置为执行:步骤S11,获取所述目标版本共享库中的所述原始符号;步骤S12,将所述原始符号添加所述用于指示所述目标版本共享库的版本的标识,得到所述替换符号;步骤S13,建立所述原始符号与所述替换符号之间的对应关系;步骤S14,将所述原始符号与所述替换符号对应存储在所述目标符号替换表中。
在其中一些实施例中,处理器480还被配置为执行:步骤S21,将所述目标版本共享库的源码文件进行编译后得到的第一文件中的所述原始符号替换为所述替换符号,得到进行符号替换后的第一文件;步骤S22,将所述进行符号替换后的第一文件经链接器进行链接后,生成所述包含所述替换符号的目标版本共享库。
在其中一些实施例中,处理器480还被配置为:在所述可执行文件同时链接多个共享库、且所述多个共享库中的每个共享库链接所述第一共享库的其中一个版本时,在对所述第一共享库的每个版本执行步骤S1和步骤S2之后,对所述多个共享库中的每个共享库执行以下步骤:步骤S3,根据所述目标符号替换表,对第二共享库中的所述原始符号进行符号替换,生成包含所述替换符号的第二共享库,其中,所述第二共享库为所述多个共享库中的其中一个,所述第二共享库链接所述目标版本共享库。
在其中一些实施例中,处理器480还被配置为执行:步骤S31,将所述第二共享库的源码文件进行编译后得到的第二文件中的所述原始符号替换为所述替换符号,得到进行符号替换后的第二文件;步骤S32,将所述进行符号替换后的第二文件经链接器进行链接后,生成所述包含所述替换符号的第二共享库。
本实施例还提供了一种具有多个版本的共享库的处理方法。图5是根据本申请实施例的具有多个版本的共享库的处理方法的流程图,如图5所示:
在可执行文件同时链接第一共享库的多个版本时,对所述第一共享库的每个版本执行以下步骤:
步骤S1,获取目标版本共享库对应的目标符号替换表,其中,所述目标版本共享库为所述第一共享库的其中一个版本,所述目标符号替换表存储有所述目标版本共享库的原始符号、以及与所述原始符号相对应的替换符号,所述替换符号为在所述原始符号的基础上添加用于指示所述目标版本共享库的版本的标识后所得到的符号;
步骤S2,根据所述目标符号替换表,对所述目标版本共享库中的所述原始符号进行符号替换,生成包含所述替换符号的目标版本共享库。
具体的,步骤S1,获取目标版本共享库对应的目标符号替换表包括:
步骤S11,获取所述目标版本共享库中的所述原始符号;
步骤S12,将所述原始符号添加所述用于指示所述目标版本共享库的版本的标识,得到所述替换符号;
步骤S13,建立所述原始符号与所述替换符号之间的对应关系;
步骤S14,将所述原始符号与所述替换符号对应存储在所述目标符号替换表中。
具体的,步骤S2,根据所述目标符号替换表,对所述目标版本共享库中的所述原始符号进行符号替换,生成包含所述替换符号的目标版本共享库包括:
步骤S21,将所述目标版本共享库的源码文件进行编译后得到的第一文件中的所述原始符号替换为所述替换符号,得到进行符号替换后的第一文件;
步骤S22,将所述进行符号替换后的第一文件经链接器进行链接后,生成所述包含所述替换符号的目标版本共享库。
以Chromium项目为例。如图6所示,Chromium源码中使用的boringssl是Google从openssl fork出来的一个分支,boringssl共享库可以看作是openssl共享库的另一个版本,二者的符号绝大部分都相同。如图6所示,当Chromium同时链接自带的boringssl共享库和系统提供的openssl共享库时,便会发生符号冲突。
为了解决符号冲突的问题,本申请实施例执行以下流程:
第1步,首先使用objdump工具导出boringssl共享库的符号。
第2步,将boringssl共享库的导出符号,统一添加上chromium_这样的前缀,构成新符号,以区分openssl共享库里面的符号。原始符号和新符号成两列一一对应,构成boringssl共享库的符号替换表。如下表所示:
第3步,改造Chromium的构建流程,加入符号替换的流程。
第4步,针对borinssl共享库和直接依赖于boringssl共享库的模块,在编译过程中,使用第2步中生成的符号替换表,对其编译后的文件执行符号替换。
在其中一些实施例中,在所述可执行文件同时链接多个共享库、且所述多个共享库中的每个共享库链接所述第一共享库的其中一个版本时,在对所述第一共享库的每个版本执行步骤S1和步骤S2之后,所述方法还包括:
对所述多个共享库中的每个共享库执行以下步骤:
步骤S3,根据所述目标符号替换表,对第二共享库中的所述原始符号进行符号替换,生成包含所述替换符号的第二共享库,其中,所述第二共享库为所述多个共享库中的其中一个,所述第二共享库链接所述目标版本共享库。
具体的,步骤S3,根据所述目标符号替换表,对第二共享库中的所述原始符号进行符号替换,生成包含所述替换符号的第二共享库包括:
步骤S31,将所述第二共享库的源码文件进行编译后得到的第二文件中的所述原始符号替换为所述替换符号,得到进行符号替换后的第二文件;
步骤S32,将所述进行符号替换后的第二文件经链接器进行链接后,生成所述包含所述替换符号的第二共享库。
针对如图7所示的情况,在不修改模块B和C(也即共享库B和C)以及共享库D的源码的情况下,可执行文件a.out运行时,B和C能够正确使用到各自所依赖的不同版本的共享库D中的符号,不发生符号冲突。
具体实现过程如下:
如图8所示,该实现过程具体包括以下步骤:
步骤S801,将共享库的符号导出为一列。在Linux操作系统下一般使用objdump工具来完成符号导出。
步骤S802,将原始符号加上表征版本信息的统一的前(后)缀,形成新符号,原始符号和新符号一起组成符号替换表。
步骤S803,重新编译共享库以及依赖它的模块,针对中间编译过程中的目标文件,使用步骤S802中的符号替换表,执行符号替换操作。在Linux操作系统下,一般用objcopy来进行符号替换,例如:
objcopy--redefine-syms symbols_file xxx.o
其中,symbols_file是记录符号替换表的文件,其每一行的第一列是原始符号,第二列是新符号;xxx.o是要进行符号替换的目标文件。
步骤S804,将进行符号替换后的目标文件,使用链接器执行链接,生成了包含新符号的共享库模块。
共享库正常的构建流程如图9所示,由于共享库D的两个版本D_v1和D_v2的源码里,符号基本都相同,所以经编译、链接后,生成的共享库libD_v1.so和libD_v2.so包含了相同的符号,会在运行时造成符号冲突。
改进后的构建流程如图10所示,在编译器及汇编器将源码文件编译成目标文件后,针对每个目标文件,使用符号替换表,执行统一地符号替换,这样最终经链接器处理生成的共享库,其不同版本也就有了不同的导出符号。
同时,针对依赖共享库D_v1的模块B,以及依赖共享库D_v2的模块C,在其各自的编译过程中,也分别执行与D_v1或D_v2相同的符号替换。这样,最终D_v1与依赖它的模块B中的相关符号,都有相同的后缀_v1,D_v2与依赖它的模块C中的相关符号,都有相同的后缀_v2。由于D_v1和D_v2中的符号不同,因此可执行文件运行时便不会发生符号冲突。
本申请通过在编译期间,将共享库的源码文件编译后的文件中的符号重命名的方式,能够很好地解决符号冲突问题,达到在不修改程序源码的情况下,让共享库的多个版本能够和平地共存的效果。
需要说明的是,不管是可执行文件直接同时链接同一个共享库的多个版本,还是可执行文件同时链接多个共享库(也称为模块)、每个模块分别依赖同一个共享库的不同版本,都适用于本申请实施例的共享库的处理方式,即都可以对每个版本的共享库及依赖它的共享库进行符号替换操作,以实现可执行文件运行时不会出现符号冲突的情况。
需要说明的是,在上述流程中或者附图的流程图中示出的步骤可以在诸如一组计算机可执行指令的计算机系统中执行,并且,虽然在流程图中示出了逻辑顺序,但是在某些情况下,可以以不同于此处的顺序执行所示出或描述的步骤。
本实施例还提供了一种具有多个版本的共享库的处理装置,该装置用于实现上述实施例及优选实施方式,已经进行过说明的不再赘述。如以下所使用的,术语“模块”、“单元”、“子单元”等可以实现预定功能的软件和/或硬件的组合。尽管以下实施例所描述的装置较佳地以软件来实现,但是硬件,或者软件和硬件的组合的实现也是可能并被构想的。
图11是根据本申请实施例的具有多个版本的共享库的处理装置的示意图,如图11所示,该装置包括:
执行单元1101,用于在可执行文件同时链接第一共享库的多个版本时,对所述第一共享库的每个版本执行以下步骤:
步骤S1,获取目标版本共享库对应的目标符号替换表,其中,所述目标版本共享库为所述第一共享库的其中一个版本,所述目标符号替换表存储有所述目标版本共享库的原始符号、以及与所述原始符号相对应的替换符号,所述替换符号为在所述原始符号的基础上添加用于指示所述目标版本共享库的版本的标识后所得到的符号;
步骤S2,根据所述目标符号替换表,对所述目标版本共享库中的所述原始符号进行符号替换,生成包含所述替换符号的目标版本共享库。
在其中一些实施例中,步骤S1,获取目标版本共享库对应的目标符号替换表包括:
步骤S11,获取所述目标版本共享库中的所述原始符号;
步骤S12,将所述原始符号添加所述用于指示所述目标版本共享库的版本的标识,得到所述替换符号;
步骤S13,建立所述原始符号与所述替换符号之间的对应关系;
步骤S14,将所述原始符号与所述替换符号对应存储在所述目标符号替换表中。
在其中一些实施例中,步骤S2,根据所述目标符号替换表,对所述目标版本共享库中的所述原始符号进行符号替换,生成包含所述替换符号的目标版本共享库包括:
步骤S21,将所述目标版本共享库的源码文件进行编译后得到的第一文件中的所述原始符号替换为所述替换符号,得到进行符号替换后的第一文件;
步骤S22,将所述进行符号替换后的第一文件经链接器进行链接后,生成所述包含所述替换符号的目标版本共享库。
在其中一些实施例中,所述装置还包括:处理单元,用于在所述可执行文件同时链接多个共享库、且所述多个共享库中的每个共享库链接所述第一共享库的其中一个版本时,在对所述第一共享库的每个版本执行步骤S1和步骤S2之后,对所述多个共享库中的每个共享库执行以下步骤:
步骤S3,根据所述目标符号替换表,对第二共享库中的所述原始符号进行符号替换,生成包含所述替换符号的第二共享库,其中,所述第二共享库为所述多个共享库中的其中一个,所述第二共享库链接所述目标版本共享库。
在其中一些实施例中,步骤S3,根据所述目标符号替换表,对第二共享库中的所述原始符号进行符号替换,生成包含所述替换符号的第二共享库包括:
步骤S31,将所述第二共享库的源码文件进行编译后得到的第二文件中的所述原始符号替换为所述替换符号,得到进行符号替换后的第二文件;
步骤S32,将所述进行符号替换后的第二文件经链接器进行链接后,生成所述包含所述替换符号的第二共享库。
需要说明的是,上述各个模块可以是功能模块也可以是程序模块,既可以通过软件来实现,也可以通过硬件来实现。对于通过硬件来实现的模块而言,上述各个模块可以位于同一处理器中;或者上述各个模块还可以按照任意组合的形式分别位于不同的处理器中。
本申请实施例还提供了一种计算机设备,结合本申请实施例具有多个版本的共享库的处理方法可以由计算机设备来实现。图12为根据本申请实施例的计算机设备的硬件结构示意图。
计算机设备可以包括处理器1201以及存储有计算机程序指令的存储器1202。
具体地,上述处理器1201可以包括中央处理器(CPU),或者特定集成电路(Application Specific Integrated Circuit,简称为ASIC),或者可以被配置成实施本申请实施例的一个或多个集成电路。
其中,存储器1202可以包括用于数据或指令的大容量存储器。举例来说而非限制,存储器1202可包括硬盘驱动器(Hard Disk Drive,简称为HDD)、软盘驱动器、固态驱动器(Solid State Drive,简称为SSD)、闪存、光盘、磁光盘、磁带或通用串行总线(UniversalSerial Bus,简称为USB)驱动器或者两个或更多个以上这些的组合。在合适的情况下,存储器1202可包括可移除或不可移除(或固定)的介质。在合适的情况下,存储器1202可在数据处理装置的内部或外部。在特定实施例中,存储器1202是非易失性(Non-Volatile)存储器。在特定实施例中,存储器1202包括只读存储器(Read-Only Memory,简称为ROM)和随机存取存储器(Random Access Memory,简称为RAM)。在合适的情况下,该ROM可以是掩模编程的ROM、可编程ROM(Programmable Read-Only Memory,简称为PROM)、可擦除PROM(ErasableProgrammable Read-Only Memory,简称为EPROM)、电可擦除PROM(Electrically ErasableProgrammable Read-Only Memory,简称为EEPROM)、电可改写ROM(ElectricallyAlterable Read-Only Memory,简称为EAROM)或闪存(FLASH)或者两个或更多个以上这些的组合。在合适的情况下,该RAM可以是静态随机存取存储器(Static Random-AccessMemory,简称为SRAM)或动态随机存取存储器(Dynamic RandomAccess Memory,简称为DRAM),其中,DRAM可以是快速页模式动态随机存取存储器(Fast Page Mode DynamicRandom Access Memory,简称为FPMDRAM)、扩展数据输出动态随机存取存储器(ExtendedDate Out Dynamic Random Access Memory,简称为EDODRAM)、同步动态随机存取内存(Synchronous Dynamic Random-Access Memory,简称SDRAM)等。
存储器1202可以用来存储或者缓存需要处理和/或通信使用的各种数据文件,以及处理器1201所执行的可能的计算机程序指令。
处理器1201通过读取并执行存储器1202中存储的计算机程序指令,以实现上述实施例中的任意一种具有多个版本的共享库的处理方法。
在其中一些实施例中,计算机设备还可包括通信接口1203和总线1204。其中,如图12所示,处理器1201、存储器1202、通信接口1203通过总线1204连接并完成相互间的通信。
通信接口1203用于实现本申请实施例中各模块、装置、单元和/或设备之间的通信。通信接口1203还可以实现与其他部件例如:外接设备、图像/数据采集设备、数据库、外部存储以及图像/数据处理工作站等之间进行数据通信。
总线1204包括硬件、软件或两者,将计算机设备的部件彼此耦接在一起。总线1204包括但不限于以下至少之一:数据总线(Data Bus)、地址总线(Address Bus)、控制总线(Control Bus)、扩展总线(Expansion Bus)、局部总线(Local Bus)。举例来说而非限制,总线1204可包括图形加速接口(Accelerated Graphics Port,简称为AGP)或其他图形总线、增强工业标准架构(Extended Industry Standard Architecture,简称为EISA)总线、前端总线(Front Side Bus,简称为FSB)、超传输(Hyper Transport,简称为HT)互连、工业标准架构(Industry Standard Architecture,简称为ISA)总线、无线带宽(InfiniBand)互连、低引脚数(Low Pin Count,简称为LPC)总线、存储器总线、微信道架构(Micro ChannelArchitecture,简称为MCA)总线、外围组件互连(Peripheral Component Interconnect,简称为PCI)总线、PCI-Express(PCI-X)总线、串行高级技术附件(Serial AdvancedTechnology Attachment,简称为SATA)总线、视频电子标准协会局部(Video ElectronicsStandards Association Local Bus,简称为VLB)总线或其他合适的总线或者两个或更多个以上这些的组合。在合适的情况下,总线1204可包括一个或多个总线。尽管本申请实施例描述和示出了特定的总线,但本申请考虑任何合适的总线或互连。
另外,结合上述实施例中的具有多个版本的共享库的处理方法,本申请实施例可提供一种计算机可读存储介质来实现。该计算机可读存储介质上存储有计算机程序指令;该计算机程序指令被处理器执行时实现上述实施例中的任意一种具有多个版本的共享库的处理方法。
以上所述实施例的各技术特征可以进行任意的组合,为使描述简洁,未对上述实施例中的各个技术特征所有可能的组合都进行描述,然而,只要这些技术特征的组合不存在矛盾,都应当认为是本说明书记载的范围。
以上所述实施例仅表达了本申请的几种实施方式,其描述较为具体和详细,但并不能因此而理解为对发明专利范围的限制。应当指出的是,对于本领域的普通技术人员来说,在不脱离本申请构思的前提下,还可以做出若干变形和改进,这些都属于本申请的保护范围。因此,本申请专利的保护范围应以所附权利要求为准。
Claims (10)
1.一种具有多个版本的共享库的处理方法,其特征在于,包括:
在可执行文件同时链接第一共享库的多个版本时,对所述第一共享库的每个版本执行以下步骤:
步骤S1,获取目标版本共享库对应的目标符号替换表,其中,所述目标版本共享库为所述第一共享库的其中一个版本,所述目标符号替换表存储有所述目标版本共享库的原始符号、以及与所述原始符号相对应的替换符号,所述替换符号为在所述原始符号的基础上添加用于指示所述目标版本共享库的版本的标识后所得到的符号;
步骤S2,根据所述目标符号替换表,对所述目标版本共享库中的所述原始符号进行符号替换,生成包含所述替换符号的目标版本共享库。
2.根据权利要求1所述的方法,其特征在于,步骤S1,获取目标版本共享库对应的目标符号替换表包括:
步骤S11,获取所述目标版本共享库中的所述原始符号;
步骤S12,将所述原始符号添加所述用于指示所述目标版本共享库的版本的标识,得到所述替换符号;
步骤S13,建立所述原始符号与所述替换符号之间的对应关系;
步骤S14,将所述原始符号与所述替换符号对应存储在所述目标符号替换表中。
3.根据权利要求1所述的方法,其特征在于,步骤S2,根据所述目标符号替换表,对所述目标版本共享库中的所述原始符号进行符号替换,生成包含所述替换符号的目标版本共享库包括:
步骤S21,将所述目标版本共享库的源码文件进行编译后得到的第一文件中的所述原始符号替换为所述替换符号,得到进行符号替换后的第一文件;
步骤S22,将所述进行符号替换后的第一文件经链接器进行链接后,生成所述包含所述替换符号的目标版本共享库。
4.根据权利要求1至3中任一项所述的方法,其特征在于,在所述可执行文件同时链接多个共享库、且所述多个共享库中的每个共享库链接所述第一共享库的其中一个版本时,在对所述第一共享库的每个版本执行步骤S1和步骤S2之后,所述方法还包括:
对所述多个共享库中的每个共享库执行以下步骤:
步骤S3,根据所述目标符号替换表,对第二共享库中的所述原始符号进行符号替换,生成包含所述替换符号的第二共享库,其中,所述第二共享库为所述多个共享库中的其中一个,所述第二共享库链接所述目标版本共享库。
5.根据权利要求4所述的方法,其特征在于,步骤S3,根据所述目标符号替换表,对第二共享库中的所述原始符号进行符号替换,生成包含所述替换符号的第二共享库包括:
步骤S31,将所述第二共享库的源码文件进行编译后得到的第二文件中的所述原始符号替换为所述替换符号,得到进行符号替换后的第二文件;
步骤S32,将所述进行符号替换后的第二文件经链接器进行链接后,生成所述包含所述替换符号的第二共享库。
6.一种具有多个版本的共享库的处理装置,其特征在于,包括:
执行单元,用于在可执行文件同时链接第一共享库的多个版本时,对所述第一共享库的每个版本执行以下步骤:
步骤S1,获取目标版本共享库对应的目标符号替换表,其中,所述目标版本共享库为所述第一共享库的其中一个版本,所述目标符号替换表存储有所述目标版本共享库的原始符号、以及与所述原始符号相对应的替换符号,所述替换符号为在所述原始符号的基础上添加用于指示所述目标版本共享库的版本的标识后所得到的符号;
步骤S2,根据所述目标符号替换表,对所述目标版本共享库中的所述原始符号进行符号替换,生成包含所述替换符号的目标版本共享库。
7.根据权利要求6所述的装置,其特征在于,步骤S1,获取目标版本共享库对应的目标符号替换表包括:
步骤S11,获取所述目标版本共享库中的所述原始符号;
步骤S12,将所述原始符号添加所述用于指示所述目标版本共享库的版本的标识,得到所述替换符号;
步骤S13,建立所述原始符号与所述替换符号之间的对应关系;
步骤S14,将所述原始符号与所述替换符号对应存储在所述目标符号替换表中。
8.根据权利要求6所述的装置,其特征在于,步骤S2,根据所述目标符号替换表,对所述目标版本共享库中的所述原始符号进行符号替换,生成包含所述替换符号的目标版本共享库包括:
步骤S21,将所述目标版本共享库的源码文件进行编译后得到的第一文件中的所述原始符号替换为所述替换符号,得到进行符号替换后的第一文件;
步骤S22,将所述进行符号替换后的第一文件经链接器进行链接后,生成所述包含所述替换符号的目标版本共享库。
9.一种计算机设备,包括存储器、处理器以及存储在所述存储器上并可在所述处理器上运行的计算机程序,其特征在于,所述处理器执行所述计算机程序时实现如权利要求1至5中任一项所述的具有多个版本的共享库的处理方法。
10.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,该程序被处理器执行时实现如权利要求1至5中任一项所述的具有多个版本的共享库的处理方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110124671.9A CN112947987A (zh) | 2021-01-29 | 2021-01-29 | 具有多个版本的共享库的处理方法和装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110124671.9A CN112947987A (zh) | 2021-01-29 | 2021-01-29 | 具有多个版本的共享库的处理方法和装置 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN112947987A true CN112947987A (zh) | 2021-06-11 |
Family
ID=76239588
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202110124671.9A Pending CN112947987A (zh) | 2021-01-29 | 2021-01-29 | 具有多个版本的共享库的处理方法和装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN112947987A (zh) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN113626100A (zh) * | 2021-07-30 | 2021-11-09 | 北京达佳互联信息技术有限公司 | 共享库处理方法、装置、电子设备及存储介质 |
CN116774988A (zh) * | 2023-08-16 | 2023-09-19 | 易方信息科技股份有限公司 | 解除框架包模式符号依赖的方法及装置 |
-
2021
- 2021-01-29 CN CN202110124671.9A patent/CN112947987A/zh active Pending
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN113626100A (zh) * | 2021-07-30 | 2021-11-09 | 北京达佳互联信息技术有限公司 | 共享库处理方法、装置、电子设备及存储介质 |
CN116774988A (zh) * | 2023-08-16 | 2023-09-19 | 易方信息科技股份有限公司 | 解除框架包模式符号依赖的方法及装置 |
CN116774988B (zh) * | 2023-08-16 | 2024-02-27 | 易方信息科技股份有限公司 | 解除框架包模式符号依赖的方法及装置 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN110032512B (zh) | 一种小程序的调试方法、相关设备及终端 | |
CN104765591A (zh) | 一种软件配置参数更新的方法、终端服务器及系统 | |
CN106502703B (zh) | 一种函数调用方法和装置 | |
CN106066686B (zh) | 一种信息处理方法及终端设备 | |
CN110378107B (zh) | 一种安装包检测的方法及相关装置 | |
CN106959859B (zh) | 系统调用函数的调用方法与装置 | |
US20200221288A1 (en) | Method for determining access method of mobile terminal, storage medium, and mobile terminal | |
US10963308B2 (en) | Method for controlling fingerprint processing resources, terminal, and computer-readable storage medium | |
CN112947987A (zh) | 具有多个版本的共享库的处理方法和装置 | |
CN103543988A (zh) | 队列消息的处理方法、控制消息进入队列的方法及装置 | |
CN104965722A (zh) | 一种显示信息的方法及装置 | |
CN109240902B (zh) | 一种获取电子设备的固件代码的方法和装置 | |
CN106534288A (zh) | 一种数据传输方法及移动终端 | |
CN111883146A (zh) | 跨平台的分布式就近唤醒方法和装置 | |
CN104699501A (zh) | 一种运行应用程序的方法及装置 | |
CN106933636B (zh) | 启动插件服务的方法、装置和终端设备 | |
CN106569916A (zh) | 一种数据备份方法及移动终端 | |
CN103944922A (zh) | 一种数据处理的方法、终端、服务器及系统 | |
CN106874038B (zh) | 一种应用安装的方法、装置以及移动终端 | |
CN109145598B (zh) | 脚本文件的病毒检测方法、装置、终端及存储介质 | |
CN105528220B (zh) | 加载动态共享对象的方法和装置 | |
CN104866288A (zh) | 一种访问应用程序的方法、装置及终端 | |
CN111736839A (zh) | 一种编译链接方法及装置 | |
EP2930616B1 (en) | Device and method for generating application package | |
CN104951324A (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 |