如何从DLL中生成LIB文件_第1页
如何从DLL中生成LIB文件_第2页
如何从DLL中生成LIB文件_第3页
如何从DLL中生成LIB文件_第4页
如何从DLL中生成LIB文件_第5页
已阅读5页,还剩6页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、如何从DLL中生成LIB文件如何从dll文件导岀对应的lib文件?Visual C+ 开发工具提供了两个命令行工具, 一个是dumpbin.exe,另一个是lib.exe。利用这两 个工具即可从dll导岀其对应的lib。1、在命令行执行:dumpb in /exports yourdll.dll > yourdll.def2、 编辑 yourdll.def文件,使之格式与.def文件格式一致。比如:EXPORTS;fn1;fn2;3、在命令行执行:lib /def:yourdll.def/machi ne:i386/out:yourdll.lib为无LIB的DLL制作LIB函数符号输入库

2、本文介绍了在VC中针对无LIB时的DLL隐式链接,制作可供VC+使用的LIB函数符号输入库。具 体步骤如下:一、使用VC+的工具DUMPBIN将DLL中的导岀函数表导岀到一定义(.DEF)文件EXAMPLE :DUMPBIN VideoDeCoder.dll /EXPROTS /OUT:VideoDeCoder.def二、将导岀的.DEF文件整理为一符合.DEF个数的函数导岀文件EXAMPLE :VideoDeCoder.DEF文件内容如下 Dump of file VideoDeCoder.dllFile Type: DLLSecti oncontains thefollowi ngexpo

3、rtsforVideoDeCoder.dll0characteristics3D49E48F timedate stampFriAug0209:46:5520020.00 version1 ordinal base11 n umber offun cti ons11n umber of n amesordi nal hint RVAn ame1000010F60_TM_ClearDecoderBuff42100010E80_TM_CloseDecoder43200010F00_TM_DecodePicture44300010ED0_TM_DecodePictureHeader45400010F

4、D0_TM_GetFileE nd46500011030_TM_GetUValue47600011060_TM_GetVValue48700011000_TM_GetYValue49800010E10_TM_Ope nDecoder810900010F30_TM_Retur nType411A00010F90_TM_SetFileE nd8Summary2000.data1000.rdata1000.reloc15000.text按照以下方法整理1)添加LIB说明LIBRARY"VideoDeCoder"DESCRIPTION "VideoDeCoder libr

5、ary"2)去掉导岀函数说明端以外的内容,在LIB说明下添加"VideoDeCoder""xx"为DLL名称"EXPROTS"说明导岀函数LIBRARYDESCRIPTION"VideoDeCoder library"EXPORTSordinal hintRVAname1000010F60_TM_ClearDecoderBuff42100010E80_TM_CloseDecoder43200010F00_TM_DecodePicture4300010ED0_TM_DecodePictureH5400010

6、FD0_TM_GetFileE nd46500011030_TM_GetUValue47600011060_TM_GetVValue48700011000_TM_GetYValue49800010E10_TM_Ope nDecoder810900010F30_TM_ReturnType411A00010F90_TM_SetFileE nd83)将所有的函数放至行首去掉 "hint" 和 "RVA" 数据,留下函数的序号"ordinal",在序号前加上"" 符号 形成"_导岀函数名参数字节和序号“此种格式(

7、_stdcall方式调用导岀的函数符号是"函数名称参数字节和").最后形成.DEF文件如下:LIBRARY"VideoDeCoder"DESCRIPTION "VideoDeCoder library"EXPORTSTM_ClearDecoderBuff4TM_CloseDecoder4TM_DecodePicture4TM_DecodePictureHeader4TM_GetFileE nd4TM_GetUValue4TM_GetVValue4TM_GetYValue4TM_Ope nDecoder8TM_ReturnType4TM

8、_SetFileE nd8三、使用VC+的LIB工具,带/DEF:(.def文件名) 格式的的LIB文件了 .1234567891011/MACHINE:IX86(80X86 机器),就输岀符合 VC+EXAMPLE:LIB /DEF:VideoDeCoder.def /MACHINE:IX86四、接时带上LIB文件链接;注意的是当有些动态库 DUMPBIN的只有函数名,无"nn"的参数格式,如 C+Builder写的DLL,输岀就只有 函数名符号,链接时就会报错:error LNK2002:unresolved externalsymbol"functionna

9、menn"提示程序中引入的函数符号无法识别,这时只要将DEF文件中相应的函数名称改为functionnamenn方式,重新建立LIB,重新链接即可.def文件格式以下摘自MSDN,希望有帮助。不过在 VC下编程好像用不着自己定义 DEF文件:模块定义(.def) 文件模块定义(.def)文件为链接器提供有关被链接程序的导岀、属性及其他方面的信息。生成DLL 时,.def文件最有用。由于存在可代替模块定义语句使用的链接器选项,通常不需要.def文件。也可以将 _declspec(dllexport)用作指定导岀函数的手段。在链接器阶段可以使用/DEF (指定模块定义文件)链接器选项调用

10、.def 文件。如果生成的.exe 文件没有导岀,使用.def文件将使输岀文件较大并降低加载速度。模块定义语句的规则下列语法规则适用于.def文件中的所有语句。其他适用于特定语句的规则与各语句一起加以说明。语句、属性关键字和用户指定的标识符区分大小写。包含空格或分号(;)的长文件名必须用引号(“) 引起。使用一个或多个空格、制表符或换行符,将语句关键字同其参数分开和将各语句分开。指定参数的 冒号(:)或等号(=)两旁有零个或多个空格、制表符或换行符。如果使用NAME 或 LIBRARY语句,则这些语句必须位于所有其他语句之前。在 .def 文件中,SECTIONS 和EXPORTS 语句可以岀

11、现多次。每个语句都可以采用多个规范,各规范间必须用一个或多个空格、制表符或换行符分开。语句关键字必须在第一个规范的前 面岀现一次,并且可以在每个附加规范的前面重复。许多语句都具有等效的LINK命令行选项。有关其他详细信息,请参阅相应的LINK 选项说明。.def 文件中的注释由每个注释行开始处的分号(;)指定。注释不能与语句共享一行,但可以在多行语句的规范间岀现。(SECTIONS 和 EXPORTS 为多行语句。)以十进制或十六进制为基础指定数值参数。如果字符串参数与保留字匹配,则必须用双引号(“) 将字符串参数引起。DESCRIPTION "text"该语句将字符串写入

12、 .rdata 节。将指定的text 用单引号或双引号( 或 ”)引起。若要在字符串中使用引号(单引号或双引号),请用其他类型的标记括住字符串。在模块定义文件中,DESCRIPTION仅在生成虚拟设备驱动程序(VxD)时有效。EXETYPE:d yn amic| dev386在模块定义文件中,EXETYPE仅在生成虚拟设备驱动程序(VxD)时有效。如果生成虚拟设备驱动程序时在模块定义文件中没有指定EXETYPE,并且如果没有指定/EXETYPE 链接器选项,则静态加载(dev386) 生效。EXPORTSdefi niti onsEXPORTS 语句引入了一个由一个或多个definitions

13、 (导岀的函数或数据)组成的节。每个定义必须在单独一行上。EXPORTS 关键字可以在第一个定义所在的同一行上或在前一行上。.def文件可以包含一个或多个 EXPORTS 语句。导岀defi ni tio ns的语法为:entryn ame=i nter naln ameordi nal NONAME PRIVATE DATAentryn ame 是要导岀的函数名或变量名。这是必选项。如果导岀的名称与DLL 中的名称不同,则通过in ternal name 指定 DLL中导岀的名称。例如,如果DLL 导岀函数func1(),要将它用作func2(),则应指定:EXPORTSfun c2=fu

14、nc1ordi nal允许指定是序号而不是函数名将进入DLL的导岀表。这有助于最小化DLL的大小。 LIB文件将包含序号与函数之间的映射,这使您得以像通常在使用DLL的项目中那样使用函数名。可选的 NONAME关键字允许只按序号导岀,并减小结果DLL中导岀表的大小。但是,如果要在DLL 上使用GetProcAddress,则必须知道序号,因为名称将无效。可选的 PRIVATE关键字禁止将entryn ame 放到由 LINK生成的导入库中。它对同样是由 LINK生成的图像中的导岀无效。可选的 DATA 关键字指定导岀的是数据,而不是代码。例如,可以导岀数据变量,如下所示:EXPORTSi DA

15、TA当对同一导岀使用PRIVATE 和 DATA 时,PRIVATE 必须位于DATA的前面。有三种导岀定义的方法,按照建议的使用顺序依次为:源代码中的_declspec(dllexport)关键字.def 文件中的EXPORTS 语句LINK命令中的/EXPORT 规范所有这三种方法可以用在同一个程序中。LINK在生成包含导岀的程序时还创建导入库,除非生成中使用了.exp 文件。以下是 EXPORTS节的示例:EXPORTSDllCa nUn loadNowDllWi ndowName = NameDllGetClassObject4DllRegisterServer7Dll Un regi

16、sterServer注意,使用 .def 文件从 DLL.declspec(dllexport)。但是,在任何使用 declspec(dllimport)。1PRIVATEDATADATANONAMEPRIVATE中导岀变量时,不需要在变量上指定DLL的文件中,仍必须在数据声明上使用LIBRARY libraryBASE=address该语句通知LINK 创建 DLL oLINK同时还创建导入库,除非生成中使用了.exp 文library 参数指定 DLL的名称。也可以使用/out 链接器选项指定 DLL输岀名。BASE=address 参数设置操作系统用来加载DLL 的基址。该参数重写 0x

17、10000000 的默认 DLL位置。有关基址的详细信息,请参阅 /BASE选项说明。请记住,在生成DLL 时使用 /DLL链接器选项。/HEAP:reserve,commitHEAPSIZE所展示的功能与/HEAP链接器选项相同。NAMEapplicatio n BASE=address链接器选项,而另/OUT 重写该语句指定主输岀文件的名称。另一种指定输岀文件名的方法是使用/out一种设置基址的方法是使用/BASE 链接器选项。如果两种方法都指定了,则NAME。如果生成DLL,NAME将只影响DLL 名SECTIONS defi niti onsSECTIONS 语句引入了一个由一个或多个

18、definitions (关于项目输岀文件各节的访问说明符)组成的节。每个定义必须在单独一行上。 SECTIONS 关键字可以在第一个定义所在的同一行或前 一行上。.def 文件可以包含一个或多个 SECTIONS 语句。该 SECTIONS 语句为图像文件中的一节或多节设置属性,并可用于重写每种节类型的默认属 性。defi ni tio ns的格式为:.sectio n_n ame specifier此处,. 为程序图像中的节名,specifier为下列一个或多个访问修饰符:EXECUTEREADSHAREDWRITE用空格分开修饰符名。例如:SECTIONS.rdata READ WRITESECTIONS 标记 defi ni tio ns 节列表的开始位置。每个定义必须在单独一行上。 SECTIONS 关键字可以在第一个定义所在的同一行或前一行上。.def 文件可以包含一个或多个 SECTIONS语句。支持 SEGMENTS 关键字作为 SECTIONS 的同义词。Visual C+的早期版本支持:secti onCLASS'class name' specifier岀

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论