然后在项目的属性里,C/C++的常规,附加包含目录里添加该文件夹。然后直接在需要使用的类里面include对应的文件。
你下的h和lib没有例程的吗?
我这里有个例子,你看看吧
hinstCadIO =LoadLibrary( "CadIOdll" );bool result;
result = true;
result &= ((dxfWriteParamString = (BOOL()(HDXF, int, LPCTSTR))
GetProcAddress( hinstCadIO, "dxfWriteParamString" )) != NULL);
result &= ((dxfWriteParamInteger = (BOOL()(HDXF, int, int))
GetProcAddress( hinstCadIO, "dxfWriteParamInteger" )) != NULL);
result &= ((dxfWriteParamDouble = (BOOL()(HDXF, int, double))
GetProcAddress( hinstCadIO, "dxfWriteParamDouble" )) != NULL);
result &= ((dxfCreateFile = (HDXF()(LPCTSTR))
GetProcAddress( hinstCadIO, "dxfCreateFile" )) != NULL);
result &= ((dxfCloseFile = (BOOL()(HDXF))
GetProcAddress( hinstCadIO, "dxfCloseFile" )) != NULL);
result &= ((dxfSetCurrentColor = (BOOL()(HDXF, int))
GetProcAddress( hinstCadIO, "dxfSetCurrentColor" )) != NULL);
result &= ((dxfSectionBegin = (BOOL()(HDXF hDxf, DWORD dwSection))
GetProcAddress( hinstCadIO, "dxfSectionBegin" )) != NULL);
result &= ((dxfSectionEnd = (BOOL(_cdecl)(HDXF hDxf))
GetProcAddress( hinstCadIO, "dxfSectionEnd" )) != NULL);
result &= ((dxfTableTypeBegin = (BOOL(_cdecl)(HDXF hDxf, DWORD dwTableType))
GetProcAddress( hinstCadIO, "dxfTableTypeBegin" )) != NULL);
result &= ((dxfTableTypeEnd = (BOOL(_cdecl)(HDXF hDxf))
GetProcAddress( hinstCadIO, "dxfTableTypeEnd" )) != NULL);
result &= ((dxfAddLayer = (BOOL(_cdecl)( HDXF hDxf, char Name, int Color, char Linetype ))
GetProcAddress( hinstCadIO, "dxfAddLayer" )) != NULL);
result &= ((dxfSetCurrentLayer = (BOOL(_cdecl)(HDXF hDxf, char Name, char LineType))
GetProcAddress( hinstCadIO, "dxfSetCurrentLayer" )) != NULL);
result &= ((dxfAddLinetype = (BOOL(_cdecl)(HDXF hDxf, PDXFLTYPE pLineType))
GetProcAddress( hinstCadIO, "dxfAddLinetype" )) != NULL);
result &= ((dxfSetCurrentLinetype = (BOOL(_cdecl)(HDXF hDxf, char Name))
GetProcAddress( hinstCadIO, "dxfSetCurrentLinetype" )) != NULL);
result &= ((dxfAddTextStyle = (BOOL(_cdecl)(HDXF hDxf, PDXFSTYLE pTextStyle))
GetProcAddress( hinstCadIO, "dxfAddTextStyle" )) != NULL);
result &= ((dxfSetCurrentTextStyle = (BOOL(_cdecl)(HDXF hDxf, char Name))
GetProcAddress( hinstCadIO, "dxfSetCurrentTextStyle" )) != NULL);
result &= ((dxfAddDimStyle = (BOOL(_cdecl)(HDXF, PDXFDIMSTYLE))
GetProcAddress( hinstCadIO, "dxfAddDimStyle" )) != NULL);
result &= ((dxfSetCurrentDimStyle = (BOOL(_cdecl)(HDXF, LPCTSTR))
GetProcAddress( hinstCadIO, "dxfSetCurrentDimStyle" )) != NULL);
result &= ((dxfLine = (BOOL(_cdecl)(HDXF hDxf, double x1, double y1, double x2, double y2))
GetProcAddress( hinstCadIO, "dxfLine" )) != NULL);
result &= ((dxfCircle = (BOOL(_cdecl)(HDXF hDxf, double cx, double cy, double r))
GetProcAddress( hinstCadIO, "dxfCircle" )) != NULL);
result &= ((dxfSolid = (BOOL(_cdecl)(HDXF hDxf, REALPOINT& Point0, REALPOINT& Point1, REALPOINT& Point2, REALPOINT& Point3))
GetProcAddress( hinstCadIO, "dxfSolid" )) != NULL);
result &= ((dxfText = (BOOL(_cdecl)( HDXF hDxf, LPCTSTR Text, double x1, double y1, double x2, double y2, double Height, double Rotation, DWORD Justification, double WidthFactor, LPCTSTR StyleName ))
GetProcAddress( hinstCadIO, "dxfText" )) != NULL);
result &= ((dxfDimLinear = (BOOL(_cdecl)( HDXF, double, double, double, double, double, double, double, LPCTSTR))
GetProcAddress( hinstCadIO, "dxfDimLinear" )) != NULL);
result &= ((dxfArc = (BOOL(_cdecl)( HDXF, double, double, double, double, double, double ))
GetProcAddress( hinstCadIO, "dxfArc" )) != NULL);
result &= ((dxfInsertBlock = (BOOL(_cdecl)( HDXF hDxf, LPCTSTR BlockName, double x, double y, double xScale, double yScale, double Rotation ))
GetProcAddress( hinstCadIO, "dxfInsertBlock" )) != NULL);
result &= ((dxfBlockBegin = (BOOL(_cdecl)( HDXF hDxf, LPCTSTR BlockName, LPCTSTR LayerName, double bx, double by, char flags ))
GetProcAddress( hinstCadIO, "dxfBlockBegin" )) != NULL);
result &= ((dxfBlockEnd = (BOOL(_cdecl)( HDXF hDxf ))
GetProcAddress( hinstCadIO, "dxfBlockEnd" )) != NULL);
if(!result)
{
// Cannot load all functions from library
return;
}
说明:先loadlibrary把库加进去,然后再把你要用的函数一个个添加进来
其中hinstCadIO是一个HINSTANCE,
(BOOL(_cdecl)( HDXF hDxf ))是一个强制类型转换成指定类型函数指针
我不知道要解释到什么程度,你要是看得懂最好,看不懂再追问
一: 隐式的加载时链接,有三种方法
1 设置工程的 Projects来加载DLL的lib文件
打开工程的 Projects菜单,然后在Linker/Additional Library Directories中加入lib文件所在的路径,在Input/Additional Dependencies加入lib文件名称,如(mylib) ,然后在要使用该函数的地方加上该LIB的头文件,如#include "\libh"即可(没有头文件当然就不用了),而且应用程序运行时也需要dll文件。
32 通过程序代码的方式
加入预编译指令#pragma comment (lib,"lib"),这种方法优点是可以利用条件预编译指令链接不同版本的LIB文件。因为,在Debug方式下,产生的LIB文件是Debug版本,如Regdlib;在Release方式下,产生的LIB文件是Release版本,如Regrlib。然后在首先要使用该函数的地方加上该LIB的头文件,如#include "\libh"即可(没有头文件当然就不用了)。
当应用程序对链接库的LIB文件加载后,还需要把链接库对应的头文件(h)包含到其中,在这个头文件中给出了链接库中定义的函数原型。
二, 显式的调用链接库
隐式链接虽然实现较简单,但除了必须的dll文件外还需要DLL的h文件和lib文件,在那些只提供dll文件的场合就无法使用,而只能采用显式链接的方式。这种方式通过调用API函数来完成对DLL的加载与卸载,能更加有效地使用内存,在编写大型应用程序时往往采用此方式。这种方法编程具体实现步骤如下:
①使用Windows API函数Load Library或者MFC提供的AfxLoadLibrary将DLL模块映像到进程的内存空间,对DLL模块进行动态加载。
②使用GetProcAddress函数得到要调用DLL中的函数的指针。
③不用DLL时,用Free Library函数或者AfxFreeLibrary函数从进程的地址空间显式卸载DLL。
例:在应用程序中调用dll文件
——在应用程序中要首先装入dll后才能调用导出表中的函数,例如用mfc
创建基于对话框的工程test,并在对话框上放置"load"按钮,先添加装载代码。
1首先在testdlgcpp的首部添加变量设置代码:
//设置全局变量glibsample用于存储dll句柄
HINSTANCE glibsample=null; //如果定义成HANDLE类型,则出错
//第二个变量showme是指向dll
库中showme()函数的指针
typedef int( Showme)(void);
Showme showme;
2利用classwizard为"load"按钮添加装载dll的代码
void ctestdlg::onloadbutton()
{
//要添加的代码如下
if(glibsample!=NULL)
{
AfxMessageBox("the sampledll has already been load");
return;
}
//装载sampledll,未加路径,将在三个默认路径中寻找 (1)windows的系统目录:\windows\system;
//(2)dos中path所指出的任何目录;
//(3)程序所在的目录;
glibsample=Loadlibrary("sampledll");
//返回dll中showme()函数的地址
showme=(Showme)GetProcAddress(glibsample,"showme");
静态链接库LIB和动态链接库DLL的区别
1什么是静态连接库,什么是动态链接库
静态链接库与动态链接库都是共享代码的方式,如果采用静态链接库,则无论你愿不愿意,lib 中的指令都全部被直接包含在最终生成的 EXE 文件中了。但是若使用 DLL,该 DLL 不必被包含在最终 EXE 文件中,EXE 文件执行时可以“动态”地引用和卸载这个与 EXE 独立的 DLL 文件。静态链接库和动态链接库的另外一个区别在于静态链接库中不能再包含其他的动态链接库或者静态库,而在动态链接库中还可以再包含其他的动态或静态链接 库。静态链接库与静态链接库调用规则总体比较如下。
对于静态链接库(比较简单):
首先,静态链接库的使用需要库的开发者提供生成库的h头文件和lib文件,应用程序运行时还依赖dll文件。
生成库的h头文件中的声明格式如下:
extern "C" 函数返回类型 函数名(参数表);
在调用程序的cpp源代码文件中如下:
#include "\libh"
#pragma comment(lib,"\\debug\\libTestlib")
//指定与静态库一起链接
第二,因为静态链接库是将全部指令都包含入调用程序生成的EXE文件中。因此如果用的是静态链接库,那么也就不存在“导出某个函数提供给用户使用”的情况,要想用就得全要!要不就都别要!:)
对于动态链接库:
动态链接库的使用需要库的开发者提供生成的lib文件,dll文件和h文件或者只提供dll和h文件。
h文件主要是知道函数原型使用。
首先我们必须先注意到DLL内的函数分为两种:
(1)DLL 导出函数,可供应用程序调用;
(2)DLL 内部函数,只能在 DLL 程序使用,应用程序无法调用它们。
因此调用程序若想调用DLL中的某个函数就要以某种形式或方式指明它到底想调用哪一个函数。第三方或者同事提供的类最好新建个文件夹,方便扩展和管理。
然后在项目的属性里,C/C++的常规,附加包含目录里添加该文件夹。然后直接在需要使用的类里面include对应的文件。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)