如果应用
程序和动态库是分别在不同开发平台上编制的,动态库的导入库(lib文件)可能会与应用
程序的开发平台所要求的导入库格式不相容,从而在应用
程序与动态库隐式链接时,出现
程序链接错误:contains invalid OMF record。例如在C++Builder开发平台上链接Visual C++制作的动态库时,就会出现上述的错误。解决这一问题,可以采用两种方法:显式连接法和使用C++Builder中提供的导入库生成工具。
RU4北方站长站 显式连接:显式连接不需要在工程中加入导入库和相应的头文件,只需要把动态库放入指定的目录下。在应用
程序中通过函数调用显式的装载和卸掉DLL,通过函数指针来调用DLL的导出函数。
RU4北方站长站 步骤:
RU4北方站长站 1. 调用LoadLibrary函数装载DLL并得到模块句柄;
RU4北方站长站 2. 调用GetProcAddress函数获取指定导出函数的指针;
RU4北方站长站 3. 用这个函数的指针调用该函数;
RU4北方站长站 4. 使用完毕后,用FreeLibrary释放DLL。
RU4北方站长站 例子:
RU4北方站长站 用VC++制作一个动态库:
RU4北方站长站 选new→Project→Win32—Dynamic—Link Library,加入addit.cpp
RU4北方站长站 extern ″C″
RU4北方站长站 {
RU4北方站长站 void __declspec( dllexport ) addit(int a, int b, int *c)
RU4北方站长站 {
RU4北方站长站 *c = a + b;
RU4北方站长站 }
RU4北方站长站 }
RU4北方站长站 addit.h
RU4北方站长站 extern ″C″
RU4北方站长站 {void addit(int a, int b, int *c);}
RU4北方站长站 编译链接生成addit.dll和addit.lib。在C++Builder
程序中调用addit函数。
RU4北方站长站 C++Builder
程序中:
RU4北方站长站 {
RU4北方站长站 HINSTANCE handle; //DLLa模块的句柄
RU4北方站长站 FARPROC lpFarProc;
RU4北方站长站 void (*lpaddit)(int,int,int *);//指向addit函数的指针
RU4北方站长站 int ntemp;
RU4北方站长站 handle = LoadLibrary(″addit.dll″); //装载addit.dll, 得到该库句柄 addit.dll位于当前目录下
RU4北方站长站 lpFarProc = GetProcAddress(handle,″addit″); //得到指向函数addit的指针
RU4北方站长站 lpaddit = (void(__cdecl *)(int, int, int *))lpFarProc; //指针类型转换
RU4北方站长站 lpaddit(2,3,&ntemp); //使用addit函数
RU4北方站长站 FreeLibrary(handle); //将addit.dll从
程序中卸掉
RU4北方站长站 }
RU4北方站长站 此
程序在VC++ 5.0 和C++Builder 3.0下通过。
RU4北方站长站 使用C++Builder中提供的导入库生成工具:先预处理,后隐式链接。
RU4北方站长站 步骤:
RU4北方站长站 1.用C++Builder提供的implib.exe工具重新生成该动态库(xxx.dll)的导入库(xxx.lib)。命令如下:
RU4北方站长站 implib addit.lib addit.dll。
RU4北方站长站 addit.dll为已有动态库,addit.lib为要生成的导入库。由此生成的导入库addit.lib格式与C++Builder开发平台是相容的;
RU4北方站长站 2.在动态库的头文件addit.h中,对其输出函数重新说明,语句如下:
RU4北方站长站 extern __stdcall void addit( int a, int b, int *c);
RU4北方站长站 3.然后采用隐式链接法,将重新生成的导入库(addit.lib)和重新说明的头文件(addit.h)加入到C++Builder应用
程序的工程项目中,进行编译和连接。
RU4北方站长站 addit.dll按上述步骤操作,在VC++ 5.0 和C++Builder 3.0下通过。
RU4北方站长站RU4北方站长站
共有 0 位网友发表了评论 此处只显示部分留言 点击查看完整评论页面