CN118467054A - 动态链接库处理方法、装置、电子设备及可读存储介质 - Google Patents
动态链接库处理方法、装置、电子设备及可读存储介质 Download PDFInfo
- Publication number
- CN118467054A CN118467054A CN202410554134.1A CN202410554134A CN118467054A CN 118467054 A CN118467054 A CN 118467054A CN 202410554134 A CN202410554134 A CN 202410554134A CN 118467054 A CN118467054 A CN 118467054A
- Authority
- CN
- China
- Prior art keywords
- function
- target
- interface
- module
- dynamic link
- 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
- 238000003672 processing method Methods 0.000 title claims description 11
- 238000013519 translation Methods 0.000 claims abstract description 73
- 238000000034 method Methods 0.000 claims abstract description 67
- 238000012545 processing Methods 0.000 claims abstract description 23
- 230000006870 function Effects 0.000 claims description 540
- 230000008569 process Effects 0.000 claims description 26
- 238000004891 communication Methods 0.000 claims description 15
- 238000012544 monitoring process Methods 0.000 claims description 9
- 238000010276 construction Methods 0.000 claims description 5
- 238000000605 extraction Methods 0.000 claims description 5
- 238000013508 migration Methods 0.000 abstract description 10
- 230000005012 migration Effects 0.000 abstract description 10
- 238000010586 diagram Methods 0.000 description 16
- 238000004590 computer program Methods 0.000 description 7
- 238000012546 transfer Methods 0.000 description 7
- 230000001419 dependent effect Effects 0.000 description 5
- 239000000284 extract Substances 0.000 description 5
- 230000009471 action Effects 0.000 description 3
- 238000005516 engineering process Methods 0.000 description 3
- 238000012217 deletion Methods 0.000 description 2
- 230000037430 deletion Effects 0.000 description 2
- 238000004458 analytical method Methods 0.000 description 1
- 238000011161 development Methods 0.000 description 1
- 230000009191 jumping Effects 0.000 description 1
- 238000004519 manufacturing process Methods 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 230000000750 progressive effect Effects 0.000 description 1
- 230000004044 response Effects 0.000 description 1
Landscapes
- Stored Programmes (AREA)
Abstract
本发明实施例提供了一种动态链接库处理方法、装置、电子设备及可读存储介质,其中的方法包括:提取第一动态链接库中每个第一函数接口的信息;第一动态链接库为在源平台下对目标模块的源文件编译得到;基于每个第一函数接口的信息,构建每个第一函数接口对应的第二函数接口,在所述目标平台下编译得到第二动态链接库;在目标平台中运行目标程序,在执行到调用目标第二函数接口的目标指令时,通过调用二进制翻译器解析目标函数在所述第一动态链接库中的起始地址,并从所述起始地址处开始翻译执行所述目标函数。本发明实施例在目标模块的源代码缺失的情况下,可以实现动态链接库的跨平台兼容,促进应用程序向新型架构平台的迁移。
Description
技术领域
本发明涉及计算机技术领域,特别是涉及一种动态链接库处理方法、装置、电子设备以及可读存储介质。
背景技术
动态链接技术是一种计算机程序设计技术,它使得应用程序可以在运行时再链接动态链接库,可以减少应用程序占用的内存空间,提高系统的效率和灵活性。
然而,动态链接库通常存在于特定架构平台中。例如,对于运行在架构平台S的应用程序P,其运行依赖于架构平台S中的动态链接库A、动态链接库B和动态链接库C。当需要基于架构平台T开发应用程序P时,如果架构平台T中缺失动态链接库A、动态链接库B和动态链接库C中的任意一个,将导致开发人员无法基于架构平台T开发应用程序P。
因此,由于动态链接库的缺失,将影响应用程序向新型架构平台的迁移。
发明内容
鉴于上述问题,提出了本发明实施例以便提供一种克服上述问题或者至少部分地解决上述问题的一种动态链接库处理方法,可以在目标模块的源代码缺失的情况下,实现动态链接库的跨平台兼容,促进应用程序向新型架构平台的迁移。
相应的,本发明实施例还提供了一种动态链接库处理装置、电子设备、以及可读存储介质,用以保证上述方法的实现及应用。
第一方面,本发明实施例公开了一种动态链接库处理方法,应用于目标平台,所述方法包括:
提取第一动态链接库中每个第一函数接口的信息;所述第一动态链接库为在源平台下对目标模块的源文件编译得到;
基于所述每个第一函数接口的信息,构建每个第一函数接口对应的第二函数接口,以得到所述目标模块在所述目标平台下的源文件,并在所述目标平台下编译所述源文件得到第二动态链接库,保存所述第二动态链接库;
在所述目标平台中运行目标程序,所述目标程序依赖于预先存储的所述第二动态链接库,所述目标程序包含调用目标第二函数接口的目标指令,所述目标第二函数接口用于调用目标函数;
在执行到所述目标指令时,通过调用二进制翻译器解析所述目标函数在所述第一动态链接库中的起始地址,并从所述起始地址处开始翻译执行所述目标函数。
第二方面,本发明实施例公开了一种动态链接库处理装置,应用于目标平台,所述装置包括:
信息提取模块,用于提取第一动态链接库中每个第一函数接口的信息;所述第一动态链接库为在源平台下对目标模块的源文件编译得到;
模块构建模块,用于基于所述每个第一函数接口的信息,构建每个第一函数接口对应的第二函数接口,以得到所述目标模块在所述目标平台下的源文件,并在所述目标平台下编译所述源文件得到第二动态链接库,保存所述第二动态链接库;
程序运行模块,用于在所述目标平台中运行目标程序,所述目标程序依赖于预先存储的所述第二动态链接库,所述目标程序包含调用目标第二函数接口的目标指令,所述目标第二函数接口用于调用目标函数;
翻译执行模块,用于在执行到所述目标指令时,通过调用二进制翻译器解析所述目标函数在所述第一动态链接库中的起始地址,并从所述起始地址处开始翻译执行所述目标函数。
第三方面,本发明实施例公开了一种电子设备,包括:处理器、存储器、通信接口和通信总线,所述处理器、所述存储器和所述通信接口通过所述通信总线完成相互间的通信;所述存储器用于存放至少一可执行指令,所述可执行指令使所述处理器执行如前述中任一所述的动态链接库处理方法的步骤。
第四方面,本发明实施例公开了一种可读存储介质,所述可读存储介质上存储程序或指令,所述程序或指令被处理器执行时能够实现本发明实施例中任一所述的动态链接库处理方法。
本发明实施例包括以下优点:
在目标模块的源文件缺失的情况下,本发明实施例在虚拟环境中提取第一动态链接库中每个第一函数接口的信息,以构建等价的第二函数接口,从而构建目标平台下的第二动态链接库,可供目标程序调用。由于目标模块的源文件缺失,构建的第二动态链接库中包含目标模块的每个模块函数的调用接口(第二库函数接口),而不包含模块函数的具体实现。当目标程序通过调用第二动态链接库中的某个第二函数接口(称为目标第二函数接口)来调用目标模块的某个函数(称为目标函数)时,本发明实施例通过调用二进制翻译器解析所述目标函数在所述第一动态链接库中的起始地址,并从所述起始地址处开始翻译执行所述目标函数。由此,在目标模块的源代码缺失的情况下,可以实现动态链接库的跨平台兼容,促进应用程序向新型架构平台的迁移。
附图说明
图1是一种目标程序依赖动态链接库的示意图;
图2是本发明的一种动态链接库处理方法实施例的步骤流程图;
图3是一个Python模块的结构示意图;
图4是本发明的一种动态链接库处理方法涉及的整体架构示意图;
图5是本发明的一种动态链接库处理装置实施例的结构框图;
图6是本发明实施例提供的电子设备的结构示意图。
具体实施方式
为使本发明的上述目的、特征和优点能够更加明显易懂,下面结合附图和具体实施方式对本发明作进一步详细的说明。
本发明的说明书和权利要求书中的术语“第一”、“第二”等是用于区别类似的对象,而不用于描述特定的顺序或先后次序。应该理解这样使用的数据在适当情况下可以互换,以便本发明的实施例能够以除了在这里图示或描述的那些以外的顺序实施,且“第一”、“第二”等所区分的对象通常为一类,并不限定对象的个数,例如第一对象可以是一个,也可以是多个。此外,说明书以及权利要求中的术语“和/或”用于描述关联对象的关联关系,表示可以存在三种关系,例如,A和/或B,可以表示:单独存在A,同时存在A和B,单独存在B这三种情况。字符“/”一般表示前后关联对象是一种“或”的关系。本发明实施例中术语“多个”是指两个或两个以上,其它量词与之类似。
二进制翻译技术可以用来解决二进制层面的应用程序跨指令集架构(Instruction Set Architecture,ISA)运行的问题。具体而言,二进制翻译技术可将一种指令集架构中的指令序列转化成另一种指令集架构中的指令序列。
在本发明实施例中,源平台也称为客户平台,目标平台也称为宿主平台或本地平台。源平台的处理器可以是基于第一指令集架构的处理器。目标平台的处理器可以是基于第二指令集架构的处理器。第二指令集架构与第一指令集架构为不同的指令集架构。例如,第一指令集架构为复杂指令集(CISC)架构,第二指令集架构为精简指令集(RISC)架构,如第一指令集架构为x86指令集架构,第二指令集架构为arm指令集架构;又如,第一指令集架构为精简指令集架构,第二指令集架构为复杂指令集架构,如第一指令集架构为arm指令集架构,第二指令集架构为x86指令集架构;除上述示例外,精简指令集架构还包括MIPS指令集架构、LoongArch(龙架构)指令集架构、PowerPC、RISC-V等。
本发明实施例可适用于如下两种场景:场景一、将已有的源平台的目标程序移植到目标平台。场景二、基于目标平台开发新的目标程序。
在场景一中,目标程序为基于源平台已开发的应用程序。也即,目标程序是基于第一指令集架构开发的程序,因此,目标程序可以在源平台上正常运行。目标平台是希望移植目标程序的机器平台。目标程序可以采用源二进制代码在源平台上运行。该源二进制代码为基于第一指令集架构的代码。如果希望在目标平台上运行该目标程序,则需要将该源二进制代码翻译成目标二进制代码。该目标二进制代码为基于第二指令集架构的代码,从而可以在目标平台上运行该目标二进制代码。也即,所述目标程序可以通过二进制翻译技术运行在所述目标平台中的二进制翻译环境下。
在场景二中,目标程序为基于目标平台开发的应用程序。也即,目标程序是基于第二指令集架构开发的程序,因此,目标程序的源二进制代码即为基于第二指令集架构的代码,可以直接运行在目标平台的本地环境下。
目标程序的运行依赖于目标模块。动态链接库的使用使得一个程序可以被分割成多个模块,每个模块可以单独编译和更新。此外,通过动态链接库可以实现插件的动态加载和卸载,为程序的功能扩展提供便利。所述目标模块可以是目标程序中的一个模块、一个插件或者一个外部库等。目标模块中定义并实现了一个或多个函数(称为模块函数或者库函数)。目标模块对外提供有函数接口,通过调用函数接口可以调用所述目标模块中相应的模块函数。目标模块可以是目标程序中的一个模块、一个插件或者一个外部库等。目标模块的源文件指的是高级语言编写的源代码文件,对目标模块的源文件进行编译后,可以得到动态链接库文件(也称为动态链接库),如.so格式的文件。
参照图1,示出了一种目标程序依赖动态链接库的示意图。如图1所示,在场景一中,目标程序在源平台(平台S)中运行需要依赖模块A、模块B和模块C,而目标平台(平台T)中缺少模块B,导致无法在平台T中翻译运行该目标程序,影响目标程序的跨平台迁移。在场景二中,需要在目标平台(平台T)中开发新的目标程序,该目标程序需要依赖模块A、模块B和模块C。由于平台T中缺少模块B,因此在编写目标程序的代码时无法编写调用模块B中的函数的代码,导致无法在平台T中开发新的目标程序,影响应用程序向新型架构平台的迁移。
为解决该问题,本发明提出了一种动态链接库处理方法。参照图2,示出了本发明的一种动态链接库处理方法实施例的步骤流程图,所述方法可应用于目标平台,所述方法可以包括如下步骤:
步骤201、提取第一动态链接库中每个第一函数接口的信息;所述第一动态链接库为在源平台下对目标模块的源文件编译得到;
步骤202、基于所述每个第一函数接口的信息,构建每个第一函数接口对应的第二函数接口,以得到所述目标模块在所述目标平台下的源文件,并在所述目标平台下编译所述源文件得到第二动态链接库,保存所述第二动态链接库;
步骤203、在所述目标平台中运行目标程序,所述目标程序依赖于预先存储的所述第二动态链接库,所述目标程序包含调用目标第二函数接口的目标指令,所述目标第二函数接口用于调用目标函数;
步骤204、在执行到所述目标指令时,通过调用二进制翻译器解析所述目标函数在所述第一动态链接库中的起始地址,并从所述起始地址处开始翻译执行所述目标函数。
本发明实施例提供的方法可应用于目标平台,实现在目标平台跨平台兼容源平台的动态链接库。需要说明的是,本发明实施例对目标平台和源平台的指令集架构不做限制。
第一动态链接库为在源平台下对目标模块的源文件进行编译得到,可运行于源平台环境。在目标平台缺少目标模块的源文件的情况下,无法在目标平台下进行编译,无法得到运行于目标平台环境的第二动态链接库。
因此,本发明实施例通过提取第一动态链接库中的每个第一函数接口的信息,构建对应的第二函数接口,从而可以恢复得到目标模块的源文件。例如,可以在目标平台下创建所述目标模块的空的源文件,在该空的源文件中构建每个第一函数接口对应的第二函数接口,例如基于高级语言在该空的源文件中添加每个第二函数接口的定义,由此得到所述目标模块在所述目标平台下的源文件。在所述目标平台下对恢复得到的该源文件进行编译,可以得到第二动态链接库,并在所述目标平台下保存该动态链接库以供后续使用,该第二动态链接库可运行于目标平台环境。
动态链接库是一个可以被多个应用程序共享的程序模块。所述目标程序依赖于预先存储的第二动态链接库,指的是所述目标程序的正常运行需要使用到所述第二动态链接库提供的功能。例如,所述目标程序在运行过程中通过调用所述第二动态链接库提供的第二函数接口,使用第二动态链接库提供的功能。其中,不同的第二函数接口可以实现不同的功能。可以理解的是,所述第二动态链接库是在目标平台下构建的与第一动态链接库等价的动态链接库,第二动态链接库与第一动态链接库提供相同的功能。
需要说明的是,本发明实施例在所述目标平台下构建得到的目标模块的源文件,其中包含第一动态链接库中的每个第一函数接口对应的第二函数接口的定义,但并不包含每个第二函数接口的具体实现。第一函数接口与第二函数接口之间具有一一对应的关系,某个第二函数接口的具体实现可以通过调用二进制翻译器对该第二函数接口对应的第一函数接口的具体实现进行翻译执行。
可以理解的是,步骤201和步骤202预先执行一次后即可保存得到的目标平台下的第二动态链接库。也即,在目标平台只需执行一次步骤201和步骤202即可,得到的该第二动态链接库可供后续的目标程序重复使用。
通过本发明实施例,在目标模块的源文件缺失的情况下,可以利用目标模块的编译文件(第一动态链接库),在目标平台构建等价的第二动态链接库,以供目标程序调用,实现动态链接库的跨平台兼容。其中,等价的含义是指,第一动态链接库和第二动态链接库提供的函数接口的功能等价。第一动态链接库中的每个第一函数接口分别对应一个等价的第二函数接口。
以图1为例,假设目标模块为模块B,模块B的源文件在源平台下编译得到的第一动态链接库如记为B.so,则在目标平台缺少B.so的情况下,可以提取B.so中的每个第一函数接口的信息;从而构建每个第一函数接口对应的第二函数接口,恢复得到模块B的源文件,并在所述目标平台下编译得到第二动态链接库,如记为B'.so。
本发明实施例中,第一动态链接库提供的函数调用接口称为第一函数接口,所述第一函数接口为源平台环境下的调用接口。例如,源平台环境下运行的目标程序可以通过调用第一函数接口调用第一动态链接库中的函数。第二动态链接库提供的函数调用接口称为第二函数接口,所述第二函数接口为目标平台环境下的调用接口。例如,目标平台环境下运行的目标程序可以通过调用第二函数接口调用第二动态链接库中的函数。
需要说明的是,由于目标模块的源文件缺失,因此,本发明实施例恢复得到的目标模块的源文件中仅包含每个第二函数接口的定义,并不包含每个第二函数接口所调用的函数的具体实现。因此,当目标程序通过调用第二动态链接库中的某个第二函数接口(称为目标第二函数接口)来调用某个函数(称为目标函数)时,本发明实施例通过调用二进制翻译器解析所述目标函数在所述第一动态链接库中的起始地址,并从所述起始地址处开始翻译执行所述目标函数。
以图1为例,在目标平台下编译得到第二动态链接库B'.so之后,对于场景一,当翻译运行的目标程序调用B.so中的第一函数接口时,本发明实施例可以翻译为调用B'.so中对应的第二函数接口。对于场景二,可以利用构建的B'.so在本地平台开发目标程序,并在开发完成后在目标平台中运行该目标程序。所述目标程序包含目标指令,所述目标指令通过调用B'.so中的目标第二函数接口,调用B'.so中的目标函数。在执行到该目标指令时,通过调用二进制翻译器解析该目标函数在B.so中的起始地址,并从该起始地址处开始翻译执行该目标函数,直至该目标函数执行结束。
本发明实施例利用源平台的第一动态链接库(如B.so),构建目标平台下等价的第二动态链接库(如B'.so),基于所述第一动态链接库和所述第二动态链接库,可以实现应用程序的跨平台迁移。
本发明提供了一种在源代码缺失的情况下实现动态链接库处理的方法。在将已有的源平台的目标程序移植到目标平台,以及基于目标平台开发新的目标程序这两种场景中,在目标平台缺失目标模块源文件的情况下,可以实现动态链接库在目标平台的跨平台兼容,从而可以为目标程序提供运行环境,帮助实现应用程序向新型架构平台的迁移。
在本发明的一种可选实施例中,所述目标模块基于第一语言编写,所述第二函数接口为所述第一语言的解释器可调用的函数接口,所述目标程序基于第二语言编写,所述目标程序在所述目标平台中通过所述解释器运行。
解释器的工作原理主要包括三个步骤:解析、编译和执行。解析是将源代码转换为抽象语法树(Abstract Syntax Tree,AST)的过程。抽象语法树是源代码的一种结构化表示形式,它将代码的语法结构转换为树形结构。编译是将抽象语法树转换为字节码的过程。字节码是一种中间代码,类似于机器码,但不直接在计算机上执行。字节码可以在解释器中被解释执行。执行是将字节码转换为机器码并在计算机上执行的过程。解释器会逐条解释执行字节码指令,并将结果返回给用户。
其中,第一语言和第二语言指的是不同的编程语言。一个示例中,第一语言为C/C++语言,第二语言为Python语言。Python语言是一种脚本语言,基于Python语言编写的程序(称为Python程序)的运行依赖于Python解释器。Python解释器可以使用不同的编程语言实现,例如java、C、C++等。常用的Python解释器是使用C/C++语言编写的,称为CPython解释器。CPython解释器可以使用C/C++编程语言按照其规定的调用规范实现Python模块,所述Python模块,可以在Python脚本语言中按照Python语言的语法直接使用而不依赖于其他的Python模块。使用C/C++编写Python模块可以获得较高的运行效率,这种编写Python模块的方式得到了广泛应用,如常见的Python模块numpy等。
在本发明实施例中,目标模块可以为使用C/C++语言按照CPython的调用规范编写的Python模块,则第一语言的解释器为CPython解释器,目标程序为Python程序。在源平台下对Python模块的源文件进行编译得到第一动态链接库。Python模块在编译后以动态链接库的形式存在。动态链接库按照可执行文件格式进行存储。
对于源代码缺失的Python模块,其不能直接在异构平台(目标平台)上被调用执行,极大削弱了新型平台上Python程序运行的兼容性。
本发明实现Python模块的跨平台兼容的主要方式是,在目标平台中构建一个与源平台的Python模块(第一动态链接库)等价的Python模块(第二动态链接库)。所述等价含义是指,两个Python模块具有相同的函数接口提供给CPython解释器调用,且函数接口的功能等价。
可以理解的是,目标模块为Python模块仅为本发明的一个应用示例,本发明实施例中主要以Python模块为例进行说明。在具体实施中,本发明对所述第一语言和第二语言不做限制。
为了在目标平台中构建与源平台的第一动态链接库等价的第二动态链接库,本发明实施例首先提取所述第一动态链接库中的每个第一函数接口的信息。对于Python模块,所述第一函数接口为Python模块向CPython解释器提供的用于调用Python模块中的模块函数的接口。示例性地,一个Python模块中定义并实现了10个模块函数。模块函数指的是目标模块(如该Python模块)中定义的函数,模块函数可以实现各种功能或操作。例如,实现加法操作的模块函数,实现乘法操作的模块函数,等等。这10个模块函数中的每个模块函数对应各自的第一函数接口,以供CPython解释器调用。提取第一动态链接库中的第一函数接口的信息,指的是提取第一动态链接库中定义的每个模块函数对应的函数接口的信息,由此可以构建对应的等价的第二函数接口。
在本发明的一种可选实施例中,所述提取第一动态链接库中每个第一函数接口的信息,可以包括:
步骤S11、在虚拟环境中加载所述第一动态链接库;
步骤S12、在加载所述第一动态链接库的过程中,在执行到模块初始化函数时,获取所述模块初始化函数的上报信息;所述上报信息包括所述第一动态链接库中每个函数的接口描述信息;
步骤S13、根据所述上报信息,解析得到每个第一函数接口的信息。
动态链接库通常包含模块初始化函数,用于上报动态链接库的一些相关信息,从中可以分析得到第一动态链接库中每个第一函数接口的信息。
所述虚拟环境指的是第一动态链接库的运行环境,如源平台环境。在虚拟环境中可以加载所述第一动态链接库,并且在加载所述第一动态链接库的过程中,在检测执行到模块初始化函数时,可以获取所述模块初始化函数的上报信息。
参照图3,示出了一个Python模块的结构示意图。如图3所示,一个C/C++语言编写的Python模块中主要包含以下几个部分:模块函数实现、函数接口描述信息、模块描述信息、以及模块初始化函数。
以图1为例,假设模块B为Python模块,在虚拟环境中加载B.so,在加载B.so的过程中,检测到执行模块初始化函数时,可以获取所述模块初始化函数的上报信息。对于Python模块,在模块初始化函数中,会按照特定的Python模块函数接口,向CPython解释器上报该Python模块的一些相关信息,如该Python模块中的函数接口描述信息和模块描述信息等。
模块初始化函数通常按照约定规则进行命名,例如,Python模块的模块初始化函数是按照Python模块的模块名称加特定字符串进行命名的。由此可以根据模块初始化函数的命名规则识别模块初始化函数。模块初始化函数通过预置结构体保存上报信息,所述上报信息包括第一动态链接库(Python模块)中每个模块函数的函数接口描述信息以及模块描述信息。其中,函数接口描述信息中包含函数接口调用的模块函数的参数信息。所述参数信息可以是调用的模块函数所需的各项参数以及各项参数的数据类型等具体的参数信息;或者,所述参数信息可以为参数标识,根据预先制定的规则,可以查询到该参数标识对应的具体的参数信息。通过解析所述上报信息,可以得到每个第一函数接口的信息。解析得到的每个第一函数接口的信息,至少包括每个第一函数接口的名称、每个第一函数接口调用的模块函数的名称、以及每个第一函数接口调用的模块函数的参数信息。
一个示例中,假设使用C语言编写了一个Python模块的源文件。在该示例中,该Python模块主要实现了一个模块函数add_int,用于求两数之和,模块函数add_int使用C语言实现。该Python模块的模块名称是demo_module。该Python模块对该模块函数add_int提供的函数接口为add。在Python程序中,通过调用函数接口add,可以调用该Python模块中的模块函数add_int。该Python模块在源平台编译后得到第一动态链接库。
本发明实施例在虚拟环境中加载该第一动态链接库,通过模块初始化函数的命名规则,可以检测到模块初始化函数。在该示例中,假设模块初始化函数的名称为PyInit_demo_module,其以“特定字符串PyInit_+模块名”的方式命名。在该模块初始化函数中,按照特定的Python模块函数接口(如PyModule_Create),向CPython解释器上报该Python模块的一些相关信息。所述相关信息包括模块描述信息和函数接口描述信息。模块描述信息通过预置结构体(如PyModuleDef)进行保存。函数接口描述信息通过预置结构体(如PyMethodDef)进行保存。
因此,本发明实施例获取所述模块初始化函数的上报信息之后,通过解析其中用于保存函数接口描述信息的预置结构体,可以得到第一函数接口的信息。
其中,所述用于保存函数接口描述信息的预置结构体中,包含函数接口的名称、该函数接口调用的模块函数的名称、以及模块函数的参数等信息。
例如,在该示例中,通过解析用于保存函数接口描述信息的预置结构体PyMethodDef,可以解析得到第一函数接口的名称为“add”,该第一函数接口的所调用的模块函数的名称为“add_int”,该模块函数的参数信息为标识“METH_VARARGS”。
Python社区中对于每一种函数的参数标识均有相关规定。例如,规定模块函数add_int的参数标识“METH_VARARGS”对应的函数参数具体为“PyObject*self,PyObject*args”。
需要说明的是,该示例中目标模块仅包含一个模块函数,本发明实施例对目标模块中包含的模块函数的数量不做限制。在具体实施中,按照上述方法提取目标模块中每个模块函数对应的第一函数接口的信息,从而可以构建每个第一函数接口对应的第二函数接口。
在本发明的一种可选实施例中,所述第一函数接口的信息包括第一函数接口的名称、该第一函数接口调用的模块函数的名称、以及该模块函数的参数信息;所述基于所述每个第一函数接口的信息,构建每个第一函数接口对应的第二函数接口,可以包括:
步骤S21、在二进制翻译器中添加供模块函数调用的翻译器运行接口;所述翻译器运行接口用于调用所述二进制翻译器;
步骤S22、创建所述目标模块在所述目标平台下的空的源文件,基于每个第一函数接口的名称、第一函数接口调用的模块函数的名称、以及第一函数接口调用的模块函数的参数信息,分别在所述源文件中定义每个第一函数接口对应的第二函数接口,定义的所述第二函数接口包括第二函数接口的名称、第二函数接口调用的模块函数的名称、以及第二函数接口调用的模块函数的参数信息,并在每个第二函数接口中调用所述翻译器运行接口。
由于目标模块的源文件缺失,无法还原目标模块中每个模块函数的具体实现,因此,本发明实施例提取第一动态链接库中的每个第一函数接口的信息,构建等价的第二函数接口,而模块函数的具体实现则通过翻译执行第一动态链接库中对应的模块函数来实现。
因此,本发明实施例构建每个第一函数接口对应的第二函数接口包括两个步骤。第一步是在二进制翻译器中添加供模块函数调用的翻译器运行接口,所述翻译器运行接口供模块函数调用,通过调用该翻译器运行接口可以调用二进制翻译器,进而可以通过二进制翻译器翻译执行目标函数。第二步是构建第二函数接口,并且在构建的每个第二函数接口中添加调用所述翻译器运行接口的操作。这样,在目标程序(或者CPython解释器)调用某个第二函数接口时,该第二函数接口会执行调用所述翻译器运行接口的操作。第二函数接口调用翻译器运行接口,可以向翻译器运行接口传递函数调用信息,如函数调用信息可以包括函数名和参数信息等。由此,二进制翻译器通过解析函数调用信息,可以在第一动态链接库中定位目标函数的起始地址,进而翻译执行目标函数。
本发明实施例构建的第二函数接口可以包括如下信息:第二函数接口调用的模块函数的名称、该模块函数的参数信息、以及翻译器运行接口。具体地,可以在目标平台下创建所述目标模块的空的源文件,基于每个第一函数接口的名称、第一函数接口调用的模块函数的名称、以及第一函数接口调用的模块函数的参数信息,分别在该空的源文件中定义每个第一函数接口对应的第二函数接口,定义的所述第二函数接口包括第二函数接口的名称、第二函数接口调用的模块函数的名称、以及第二函数接口调用的模块函数的参数信息,并在每个第二函数接口中调用所述翻译器运行接口。由此得到目标模块在目标平台下的源文件,该源文件中包含第一动态链接库中每个第一函数接口对应的第二函数接口的定义。其中,构建的第二函数接口的名称与该第二函数接口相对应的第一函数接口的名称可以相同。第二函数接口调用的模块函数的名称与该第二函数接口相对应的第一函数接口调用的模块函数的名称可以相同。第二函数接口调用的模块函数的参数信息与该第二函数接口相对应的第一函数接口调用的模块函数的参数信息可以相同。本发明实施例构建的第二函数接口并不包含第二函数接口调用的模块函数的具体实现。
其中,翻译器运行接口可以实现如下功能:解析目标函数的调用信息,初始化二进制翻译环境,跳转到第一动态链接库中目标函数的起始地址处翻译执行。需要说明的是,所述初始化二进制翻译环境只需要执行一次,不用每次都执行。
在本发明的一种可选实施例中,所述通过调用二进制翻译器解析所述目标函数在所述第一动态链接库中的起始地址,可以包括:
步骤S31、在执行到所述目标指令时,所述目标指令通过调用目标第二函数接口,调用所述目标第二函数接口中的翻译器运行接口,并向所述翻译器运行接口传递所述目标函数的调用信息,所述调用信息包括所述目标函数的函数名和参数信息;
步骤S32、所述翻译器运行接口调用所述二进制翻译器,并向所述二进制翻译器传递所述目标函数的调用信息;
步骤S33、所述二进制翻译器通过所述调用信息中的函数名,在所述第一动态链接库文件中查找所述目标函数的起始地址。
本发明实施例在构建的第二函数接口中,利用二进制翻译的方式,初始化二进制翻译环境(源平台运行环境),在二进制翻译环境下加载第一动态链接库,翻译执行第一动态链接库中的目标函数。
一个示例中,在目标平台环境下运行目标程序,在执行到所述目标程序中的目标指令时,所述目标指令通过调用目标第二函数接口(如add),以调用目标函数(如add_int),目标第二函数接口会调用翻译器运行接口,并向所述翻译器运行接口传递目标函数的调用信息,所述调用信息包括目标函数的函数名(如add_int)和参数信息(如METH_VARARGS)。
所述翻译器运行接口调用所述二进制翻译器,并向所述二进制翻译器传递所述目标函数的调用信息;所述二进制翻译器通过所述调用信息中的函数名(如add_int),可以在所述第一动态链接库文件中查找到所述目标函数的起始地址,进而可以从开起始地址处翻译执行目标函数。
在本发明的一种可选实施例中,所述方法还可以包括:
在翻译执行所述目标函数的过程中,当监控到所述目标函数调用二进制翻译环境下的解释器相关接口时,将调用所述二进制翻译环境下的解释器相关接口修改为调用目标平台的解释器相关接口;其中,所述解释器相关接口包括:所述解释器向所述二进制翻译器传递目标函数的参数值的接口,和/或,所述二进制翻译器向所述解释器返回目标函数执行结果的接口。
在目标平台中的二进制翻译环境下翻译执行目标模块(如Python模块)中的目标函数的过程中,目标函数可能会调用解释器相关接口(如CPython解释器提供的相关API)。在目标模块的编写语言与目标程序的编写语言不同时,例如,Python模块是使用C语言编写的,而目标程序是使用Python编写的,Python语言编写的代码需要通过Cpython解释器运行,使用C语言编写的Python模块中的模块函数(如add_int)与Python程序中调用的第二函数接口(如add)之间,需要依靠CPython解释器提供的相关接口传递数据。
示例性地,二进制翻译器在翻译执行目标函数add_int的过程中,通过调用解释器相关接口,可以向解释器获取目标函数的参数值,也即Python程序调用目标第二函数接口add时传入的参数值。由此,目标函数add_int可以基于获取的参数值计算得到执行结果,再通过调用解释器相关接口,向解释器返回执行结果,解释器最终将执行结果返回给Python程序。
在本发明实施例中,Python程序运行在目标平台的本地环境下,而Python模块运行在二进制翻译环境下(也即模拟的源平台环境下)。如果翻译运行CPython解释器的相关API(Application Programming Interface,应用程序编程接口),将导致Python程序和Python模块通过不同环境下的两个CPython解释器进行数据传递,进而导致数据传递出错的问题。因此,本发明实施例在翻译执行目标函数的过程中,监控目标函数是否调用解释器相关接口。若监控到目标函数调用解释器相关接口,此时目标函数调用的是二进制翻译环境下的解释器相关接口,本发明实施例将调用所述二进制翻译环境下的解释器相关接口修改为调用目标平台的解释器相关接口。由此可以保证Python程序和Python模块通过同一个CPython解释器(运行在目标平台本地环境下的CPython解释器)进行数据传递,可以保证数据传递正确。进而,目标平台的解释器可以响应解释器相关接口的调用,向二进制翻译器中的目标函数传递参数值,或者接收来自目标函数返回的执行结果。
在本发明的一种可选实施例中,所述方法还可以包括:
从所述解释器的头文件中提取所有解释器相关接口的信息,并保存在所述二进制翻译环境下。
为了在翻译执行所述目标函数的过程中,可以实现监控所述目标函数是否调用解释器相关接口。本发明实施例预先获取所述解释器的头文件,根据函数定义规则从所述头文件中提取所有解释器相关接口的信息,并保存在所述二进制翻译环境下。
所述监控到所述目标函数调用二进制翻译环境下的解释器相关接口,可以包括:在翻译执行所述目标函数的过程中,对所述目标函数调用的当前接口与保存的解释器相关接口进行比对,若二者相匹配,则确定监控到所述目标函数调用二进制翻译环境下的解释器相关接口。
在翻译执行目标函数的过程中,对目标函数调用的每个接口都与二进制翻译环境下保存的解释器相关接口进行比对;若二者相匹配,则确定监控到所述目标函数调用二进制翻译环境下的解释器相关接口,则修改为调用目标平台的解释器相关接口。
以目标模块为C/C++语言编写的Python模块,目标程序为Python程序为例,参照图4,示出了本发明动态链接库处理方法涉及的整体架构示意图。如图4所示,本发明应用于目标平台,所述目标平台中运行有Python程序、CPython解释器环境、以及二进制翻译环境。本发明的动态链接库处理方法可以包括如下三个部分的内容:提取第一函数接口的信息、翻译运行目标函数、以及CPython解释器相关接口的调用处理。
其中,提取第一函数接口的信息,指的是在虚拟环境下加载第一动态链接库,基于模块初始化函数的上报信息提取第一动态链接库中每个第一函数接口的信息,从而构建每个第一函数接口对应的第二函数接口,并在所述目标平台下编译得到第二动态链接库。
翻译运行目标函数,指的是在所述目标平台中运行目标程序,所述目标程序包含调用目标第二函数接口的目标指令,所述目标第二函数接口用于调用目标函数;在执行到所述目标指令时,通过调用二进制翻译器解析所述目标函数在所述第一动态链接库中的起始地址,并从所述起始地址处开始翻译执行所述目标函数。
CPython解释器相关接口的调用处理,指的是在翻译执行所述目标函数的过程中,当监控到所述目标函数调用二进制翻译环境下的解释器相关接口时,将调用所述二进制翻译环境下的解释器相关接口修改为调用目标平台的解释器相关接口。具体地,将所述目标函数调用二进制翻译环境下的解释器相关接口的地址称为第一地址。当监控到目标函数调用的当前接口的名称与二进制翻译环境下保存的某个解释器相关接口的名称相匹配时,则确定监控到所述目标函数调用二进制翻译环境下的解释器相关接口。根据调用的当前接口的名称查找运行在目标平台本地环境下的CPython解释器的库文件,根据所述当前接口的名称在该库文件中进行查找,得到调用目标平台本地环境下的该解释器相关接口的第二地址。将所述目标函数调用解释器相关接口的第一地址修改为第二地址。
如图4所示,目标模块为Python模块,Python模块中包含Method1~Method1这n个模块函数。Python模块的源文件在源平台下编译后得到第一动态链接库。在缺失Python模块的源文件的情况下,本发明实施例在目标平台的二进制翻译环境下加载第一动态链接库,提取第一动态链接库中每个第一函数接口的信息,构建每个第一函数接口对应的第二函数接口,恢复得到目标模块的源文件,并在所述目标平台下编译得到第二动态链接库。
如图4所示,二进制翻译环境下的Python模块也即第一动态链接库,CPython解释器环境下的Python模块也即本发明构建的第二动态链接库。第一动态链接库中包含Method1~Method1这n个模块函数分别对应的第一函数接口以及每个模块函数的具体实现。第二动态链接库中包含Method1~Method1这n个模块函数分别对应的第二函数接口,但不包含每个模块函数的具体实现。
在执行到Python程序中的目标指令时,假设目标指令通过目标第二函数接口调用目标函数Method2,则通过调用二进制翻译器解析所述目标函数Method2在第一动态链接库中的起始地址,并从所述起始地址处开始翻译执行目标函数Method2。在翻译执行目标函数Method2的过程中,监控目标函数Method2是否调用解释器相关接口。若监控到目标函数Method2调用解释器相关接口,则进行调用处理,将调用二进制翻译环境下的解释器相关接口修改为调用目标平台的解释器相关接口。由此,实现在源代码缺失的情况下,可以在目标平台兼容运行C/C++语言编写的Python模块,并且保证Python程序与Python模块之间数据传递的正确性。
综上,通过本发明实施例,在目标模块的源文件缺失的情况下,提取第一动态链接库中每个第一函数接口的信息,构建等价的第二函数接口,从而构建目标平台下的第二动态链接库,以供目标程序调用。由于目标模块的源文件缺失,构建的第二动态链接库中包括目标模块的每个模块函数的调用接口(第二库函数接口),而不包括模块函数的具体实现。当目标程序通过调用第二动态链接库中的某个第二函数接口(称为目标第二函数接口)来调用某个函数(称为目标函数)时,本发明实施例通过调用二进制翻译器解析所述目标函数在所述第一动态链接库中的起始地址,并从所述起始地址处开始翻译执行所述目标函数。由此,在目标模块的源代码缺失的情况下,可以实现动态链接库的跨平台兼容,促进应用程序向新型架构平台的迁移。
需要说明的是,对于方法实施例,为了简单描述,故将其都表述为一系列的动作组合,但是本领域技术人员应该知悉,本发明实施例并不受所描述的动作顺序的限制,因为依据本发明实施例,某些步骤可以采用其他顺序或者同时进行。其次,本领域技术人员也应该知悉,说明书中所描述的实施例均属于优选实施例,所涉及的动作并不一定是本发明实施例所必须的。
参照图5,示出了本发明的一种动态链接库处理装置实施例的结构框图,所述装置应用于目标平台,所述装置可以包括:
信息提取模块501,用于提取第一动态链接库中每个第一函数接口的信息;所述第一动态链接库为在源平台下对目标模块的源文件编译得到;
模块构建模块502,用于基于所述每个第一函数接口的信息,构建每个第一函数接口对应的第二函数接口,以得到所述目标模块在所述目标平台下的源文件,并在所述目标平台下编译所述源文件得到第二动态链接库,保存所述第二动态链接库;
程序运行模块503,用于在所述目标平台中运行目标程序,所述目标程序依赖于预先存储的所述第二动态链接库,所述目标程序包含调用目标第二函数接口的目标指令,所述目标第二函数接口用于调用目标函数;
翻译执行模块504,用于在执行到所述目标指令时,通过调用二进制翻译器解析所述目标函数在所述第一动态链接库中的起始地址,并从所述起始地址处开始翻译执行所述目标函数。
可选地,所述目标模块基于第一语言编写,所述第二函数接口为所述第一语言的解释器可调用的函数接口,所述目标程序基于第二语言编写,所述目标程序在所述目标平台中通过所述解释器运行。
可选地,所述装置还包括:
监控处理模块,用于在翻译执行所述目标函数的过程中,当监控到所述目标函数调用二进制翻译环境下的解释器相关接口时,将调用所述二进制翻译环境下的解释器相关接口修改为调用目标平台的解释器相关接口;其中,所述解释器相关接口包括:所述解释器向所述二进制翻译器传递目标函数的参数值的接口,和/或,所述二进制翻译器向所述解释器返回目标函数执行结果的接口。
可选地,所述装置还包括:
信息保存模块,用于从所述解释器的头文件中提取所有解释器相关接口的信息,并保存在所述二进制翻译环境下;
所述监控处理模块,具体用于在翻译执行所述目标函数的过程中,对所述目标函数调用的当前接口与保存的解释器相关接口进行比对,若二者相匹配,则确定监控到所述目标函数调用二进制翻译环境下的解释器相关接口。
可选地,所述信息提取模块,具体用于:在虚拟环境中加载所述第一动态链接库;在加载所述第一动态链接库的过程中,在执行到模块初始化函数时,获取所述模块初始化函数的上报信息;所述上报信息包括所述第一动态链接库中每个函数的接口描述信息;根据所述上报信息,解析得到每个第一函数接口的信息。
可选地,所述第一函数接口的信息包括第一函数接口的名称、该第一函数接口调用的模块函数的名称、以及该模块函数的参数信息;
所述模块构建模块,具体用于:在二进制翻译器中添加供模块函数调用的翻译器运行接口;所述翻译器运行接口用于调用所述二进制翻译器;创建所述目标模块在所述目标平台下的空的源文件,基于每个第一函数接口的名称、第一函数接口调用的模块函数的名称、以及第一函数接口调用的模块函数的参数信息,分别在所述源文件中定义每个第一函数接口对应的第二函数接口,定义的所述第二函数接口包括第二函数接口的名称、第二函数接口调用的模块函数的名称、以及第二函数接口调用的模块函数的参数信息,并在每个第二函数接口中调用所述翻译器运行接口。
可选地,所述翻译执行模块,具体用于:在执行到所述目标指令时,所述目标指令通过调用目标第二函数接口,调用所述目标第二函数接口中的翻译器运行接口,并向所述翻译器运行接口传递所述目标函数的调用信息,所述调用信息包括所述目标函数的函数名和参数信息;所述翻译器运行接口调用所述二进制翻译器,并向所述二进制翻译器传递所述目标函数的调用信息;所述二进制翻译器通过所述调用信息中的函数名,在所述第一动态链接库文件中查找所述目标函数的起始地址。
可选地,所述目标程序为基于所述源平台开发的应用程序,所述目标程序运行在所述目标平台中的二进制翻译环境下;或者,所述目标程序为基于所述目标平台开发的应用程序,所述目标程序运行在所述目标平台的本地环境下;所述目标程序的运行依赖于所述目标模块。
通过本发明实施例,在目标模块的源文件缺失的情况下,提取第一动态链接库中每个第一函数接口的信息,构建等价的第二函数接口,从而构建目标平台下的第二动态链接库,以供目标程序调用。由于目标模块的源文件缺失,构建的第二动态链接库中包括目标模块的每个模块函数的调用接口(第二库函数接口),而不包括模块函数的具体实现。当目标程序通过调用第二动态链接库中的某个第二函数接口(称为目标第二函数接口)来调用某个函数(称为目标函数)时,本发明实施例通过调用二进制翻译器解析所述目标函数在所述第一动态链接库中的起始地址,并从所述起始地址处开始翻译执行所述目标函数。由此,在目标模块的源代码缺失的情况下,可以实现动态链接库的跨平台兼容,促进应用程序向新型架构平台的迁移。
对于装置实施例而言,由于其与方法实施例基本相似,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。
参照图6,是本发明实施例提供的电子设备的结构示意图。如图6所示,所述电子设备包括:处理器、存储器、通信接口和通信总线,所述处理器、所述存储器和所述通信接口通过所述通信总线完成相互间的通信;所述存储器用于存放至少一可执行指令,所述可执行指令使所述处理器执行前述实施例的动态链接库处理方法的步骤。
本发明实施例提供了一种非临时性计算机可读存储介质,当所述存储介质中的指令由终端的程序或处理器执行时,使得终端能够执行前述任一实施例的动态链接库处理方法的步骤。
本说明书中的各个实施例均采用递进的方式描述,每个实施例重点说明的都是与其他实施例的不同之处,各个实施例之间相同相似的部分互相参见即可。
本领域内的技术人员应明白,本发明实施例的实施例可提供为方法、装置、或存储介质。因此,本发明实施例可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本发明实施例可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
本发明实施例是参照根据本发明实施例的方法、终端设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理终端设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理终端设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理终端设备以预测方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理终端设备上,使得在计算机或其他可编程终端设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程终端设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
最后,还需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者终端设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者终端设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者终端设备中还存在另外的相同要素。
本文中应用了具体个例对本发明的原理及实施方式进行了阐述,以上实施例的说明只是用于帮助理解本发明的方法及其核心思想;同时,对于本领域的一般技术人员,依据本发明的思想,在具体实施方式及应用范围上均会有改变之处,综上所述,本说明书内容不应理解为对本发明的限制。
Claims (18)
1.一种动态链接库处理方法,其特征在于,应用于目标平台,所述方法包括:
提取第一动态链接库中每个第一函数接口的信息;所述第一动态链接库为在源平台下对目标模块的源文件编译得到;
基于所述每个第一函数接口的信息,构建每个第一函数接口对应的第二函数接口,以得到所述目标模块在所述目标平台下的源文件,并在所述目标平台下编译所述源文件得到第二动态链接库,保存所述第二动态链接库;
在所述目标平台中运行目标程序,所述目标程序依赖于预先存储的所述第二动态链接库,所述目标程序包含调用目标第二函数接口的目标指令,所述目标第二函数接口用于调用目标函数;
在执行到所述目标指令时,通过调用二进制翻译器解析所述目标函数在所述第一动态链接库中的起始地址,并从所述起始地址处开始翻译执行所述目标函数。
2.根据权利要求1所述的方法,其特征在于,所述目标模块基于第一语言编写,所述第二函数接口为所述第一语言的解释器可调用的函数接口,所述目标程序基于第二语言编写,所述目标程序在所述目标平台中通过所述解释器运行。
3.根据权利要求2所述的方法,其特征在于,所述方法还包括:
在翻译执行所述目标函数的过程中,当监控到所述目标函数调用二进制翻译环境下的解释器相关接口时,将调用所述二进制翻译环境下的解释器相关接口修改为调用目标平台的解释器相关接口;其中,所述解释器相关接口包括:所述解释器向所述二进制翻译器传递目标函数的参数值的接口,和/或,所述二进制翻译器向所述解释器返回目标函数执行结果的接口。
4.根据权利要求3所述的方法,其特征在于,所述方法还包括:
从所述解释器的头文件中提取所有解释器相关接口的信息,并保存在所述二进制翻译环境下;
所述监控到所述目标函数调用二进制翻译环境下的解释器相关接口,包括:
在翻译执行所述目标函数的过程中,对所述目标函数调用的当前接口与保存的解释器相关接口进行比对,若二者相匹配,则确定监控到所述目标函数调用二进制翻译环境下的解释器相关接口。
5.根据权利要求1至4任一项所述的方法,其特征在于,所述提取第一动态链接库中每个第一函数接口的信息,包括:
在虚拟环境中加载所述第一动态链接库;
在加载所述第一动态链接库的过程中,在执行到模块初始化函数时,获取所述模块初始化函数的上报信息;所述上报信息包括所述第一动态链接库中每个函数的接口描述信息;
根据所述上报信息,解析得到每个第一函数接口的信息。
6.根据权利要求1至4任一项所述的方法,其特征在于,所述第一函数接口的信息包括第一函数接口的名称、该第一函数接口调用的模块函数的名称、以及该模块函数的参数信息;所述基于所述每个第一函数接口的信息,构建每个第一函数接口对应的第二函数接口,包括:
在二进制翻译器中添加供模块函数调用的翻译器运行接口;所述翻译器运行接口用于调用所述二进制翻译器;
创建所述目标模块在所述目标平台下的空的源文件,基于每个第一函数接口的名称、第一函数接口调用的模块函数的名称、以及第一函数接口调用的模块函数的参数信息,分别在所述源文件中定义每个第一函数接口对应的第二函数接口,定义的所述第二函数接口包括第二函数接口的名称、第二函数接口调用的模块函数的名称、以及第二函数接口调用的模块函数的参数信息,并在每个第二函数接口中调用所述翻译器运行接口。
7.根据权利要求6所述的方法,其特征在于,所述通过调用二进制翻译器解析所述目标函数在所述第一动态链接库中的起始地址,包括:
在执行到所述目标指令时,所述目标指令通过调用目标第二函数接口,调用所述目标第二函数接口中的翻译器运行接口,并向所述翻译器运行接口传递所述目标函数的调用信息,所述调用信息包括所述目标函数的函数名和参数信息;
所述翻译器运行接口调用所述二进制翻译器,并向所述二进制翻译器传递所述目标函数的调用信息;
所述二进制翻译器通过所述调用信息中的函数名,在所述第一动态链接库文件中查找所述目标函数的起始地址。
8.根据权利要求1至4任一项所述的方法,其特征在于,所述目标程序为基于所述源平台开发的应用程序,所述目标程序运行在所述目标平台中的二进制翻译环境下;或者,所述目标程序为基于所述目标平台开发的应用程序,所述目标程序运行在所述目标平台的本地环境下;所述目标程序的运行依赖于所述目标模块。
9.一种动态链接库处理装置,其特征在于,应用于目标平台,所述装置包括:
信息提取模块,用于提取第一动态链接库中每个第一函数接口的信息;所述第一动态链接库为在源平台下对目标模块的源文件编译得到;
模块构建模块,用于基于所述每个第一函数接口的信息,构建每个第一函数接口对应的第二函数接口,以得到所述目标模块在所述目标平台下的源文件,并在所述目标平台下编译所述源文件得到第二动态链接库,保存所述第二动态链接库;
程序运行模块,用于在所述目标平台中运行目标程序,所述目标程序依赖于预先存储的所述第二动态链接库,所述目标程序包含调用目标第二函数接口的目标指令,所述目标第二函数接口用于调用目标函数;
翻译执行模块,用于在执行到所述目标指令时,通过调用二进制翻译器解析所述目标函数在所述第一动态链接库中的起始地址,并从所述起始地址处开始翻译执行所述目标函数。
10.根据权利要求9所述的装置,其特征在于,所述目标模块基于第一语言编写,所述第二函数接口为所述第一语言的解释器可调用的函数接口,所述目标程序基于第二语言编写,所述目标程序在所述目标平台中通过所述解释器运行。
11.根据权利要求10所述的装置,其特征在于,所述装置还包括:
监控处理模块,用于在翻译执行所述目标函数的过程中,当监控到所述目标函数调用二进制翻译环境下的解释器相关接口时,将调用所述二进制翻译环境下的解释器相关接口修改为调用目标平台的解释器相关接口;其中,所述解释器相关接口包括:所述解释器向所述二进制翻译器传递目标函数的参数值的接口,和/或,所述二进制翻译器向所述解释器返回目标函数执行结果的接口。
12.根据权利要求11所述的装置,其特征在于,所述装置还包括:
信息保存模块,用于从所述解释器的头文件中提取所有解释器相关接口的信息,并保存在所述二进制翻译环境下;
所述监控处理模块,具体用于在翻译执行所述目标函数的过程中,对所述目标函数调用的当前接口与保存的解释器相关接口进行比对,若二者相匹配,则确定监控到所述目标函数调用二进制翻译环境下的解释器相关接口。
13.根据权利要求9至12任一项所述的装置,其特征在于,所述信息提取模块,具体用于:在虚拟环境中加载所述第一动态链接库;在加载所述第一动态链接库的过程中,在执行到模块初始化函数时,获取所述模块初始化函数的上报信息;所述上报信息包括所述第一动态链接库中每个函数的接口描述信息;根据所述上报信息,解析得到每个第一函数接口的信息。
14.根据权利要求9至12任一项所述的装置,其特征在于,所述第一函数接口的信息包括第一函数接口的名称、该第一函数接口调用的模块函数的名称、以及该模块函数的参数信息;
所述模块构建模块,具体用于:在二进制翻译器中添加供模块函数调用的翻译器运行接口;所述翻译器运行接口用于调用所述二进制翻译器;创建所述目标模块在所述目标平台下的空的源文件,基于每个第一函数接口的名称、第一函数接口调用的模块函数的名称、以及第一函数接口调用的模块函数的参数信息,分别在所述源文件中定义每个第一函数接口对应的第二函数接口,定义的所述第二函数接口包括第二函数接口的名称、第二函数接口调用的模块函数的名称、以及第二函数接口调用的模块函数的参数信息,并在每个第二函数接口中调用所述翻译器运行接口。
15.根据权利要求14所述的装置,其特征在于,所述翻译执行模块,具体用于:在执行到所述目标指令时,所述目标指令通过调用目标第二函数接口,调用所述目标第二函数接口中的翻译器运行接口,并向所述翻译器运行接口传递所述目标函数的调用信息,所述调用信息包括所述目标函数的函数名和参数信息;所述翻译器运行接口调用所述二进制翻译器,并向所述二进制翻译器传递所述目标函数的调用信息;所述二进制翻译器通过所述调用信息中的函数名,在所述第一动态链接库文件中查找所述目标函数的起始地址。
16.根据权利要求9至12任一项所述的装置,其特征在于,所述目标程序为基于所述源平台开发的应用程序,所述目标程序运行在所述目标平台中的二进制翻译环境下;或者,所述目标程序为基于所述目标平台开发的应用程序,所述目标程序运行在所述目标平台的本地环境下;所述目标程序的运行依赖于所述目标模块。
17.一种电子设备,其特征在于,包括:处理器、存储器、通信接口和通信总线,所述处理器、所述存储器和所述通信接口通过所述通信总线完成相互间的通信;所述存储器用于存放至少一可执行指令,所述可执行指令使所述处理器执行如权利要求1至8任一所述的动态链接库处理方法的步骤。
18.一种可读存储介质,其特征在于,所述可读存储介质上存储程序或指令,所述程序或指令被处理器执行时实现如权利要求1至8任一所述的动态链接库处理方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202410554134.1A CN118467054A (zh) | 2024-05-07 | 2024-05-07 | 动态链接库处理方法、装置、电子设备及可读存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202410554134.1A CN118467054A (zh) | 2024-05-07 | 2024-05-07 | 动态链接库处理方法、装置、电子设备及可读存储介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN118467054A true CN118467054A (zh) | 2024-08-09 |
Family
ID=92162971
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202410554134.1A Pending CN118467054A (zh) | 2024-05-07 | 2024-05-07 | 动态链接库处理方法、装置、电子设备及可读存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN118467054A (zh) |
-
2024
- 2024-05-07 CN CN202410554134.1A patent/CN118467054A/zh active Pending
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN108920133B (zh) | 跨语言编程方法、装置、电子设备及存储介质 | |
CN110149800B (zh) | 一种用于处理与源程序的源代码相关联的抽象语法树的装置 | |
US8707263B2 (en) | Using a DSL for calling APIS to test software | |
US7346897B2 (en) | System for translating programming languages | |
US20220261229A1 (en) | Accessing a migrated member in an updated type | |
EP3971706B1 (en) | Method, apparatus and electronic device for deploying operator in deep learning frame work | |
US20160232017A1 (en) | System and Method for Reloading Constructors | |
US9524175B2 (en) | Target typing of overloaded method and constructor arguments | |
US20150242194A1 (en) | System for Translating Diverse Programming Languages | |
US9207920B2 (en) | Systems and methods for remote analysis of software applications | |
JP5396979B2 (ja) | ソフトウェア開発支援装置、システム、ソフトウェア開発支援装置の機能拡張方法、及びプログラム | |
US20160246622A1 (en) | Method and system for implementing invocation stubs for the application programming interfaces embedding with function overload resolution for dynamic computer programming languages | |
EP3698241A1 (en) | Using semantic annotations to control compatibility behaviors | |
CN111427583A (zh) | 组件的编译方法、装置和电子设备及计算机可读存储介质 | |
CN114116134A (zh) | 智能合约部署和执行方法、设备及存储介质 | |
CN113703779A (zh) | 一种跨平台的多语言编译方法和超轻量物联网虚拟机 | |
US10983771B1 (en) | Quality checking inferred types in a set of code | |
CN115390846A (zh) | 编译构建方法、装置、电子设备和存储介质 | |
WO2011042228A1 (en) | Method and system to handle java class versioning | |
CN112000334A (zh) | 页面开发方法、装置、服务器及存储介质 | |
CN114610364A (zh) | 应用程序更新、应用程序开发方法、装置及计算机设备 | |
CN111158665B (zh) | 代码生成方法及装置、电子设备和存储介质 | |
CN107315599B (zh) | 图形库提取方法及装置 | |
CN117149215A (zh) | 反汇编信息输出方法、装置、电子设备及存储介质 | |
CN114168151B (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 |