参考该博客:https://www.cnblogs.com/TenosDoIt/p/3203137.html
1.基本概念
首先,介绍下动态链接库和静态链接库的概念,两者都是代码共享的方式。
静态库:在链接步骤中,链接器将从库文件中取得代码,复制到可执行文件中,此种称为静态库。其特点是可执行文件中包含了库代码的一份完整拷贝;缺点就是被多次使用就会有多份冗余拷贝。即静态库中的指令都全部被直接包含在最终生成的 EXE 文件中了。在vs中新建生成静态库的工程,编译生成成功后,只产生一个.lib文件
动态库:动态链接库是一个包含可由多个程序同时使用的代码和数据的库,DLL不是可执行文件。动态链接提供了一种方法,使进程可以调用不属于其可执行代码的函数。函数的可执行代码位于一个 DLL 中,该 DLL 包含一个或多个已被编译、链接并与使用它们的进程分开存储的函数。在vs中新建生成动态库的工程,编译成功后,产生一个.lib文件和一个.dll文件
2.静态库和动态库的LIB文件有什么区别呢?
静态库中的LIB:该LIB包含函数代码本身(即包括函数的索引,也包括实现),在编译时直接将代码加入程序当中。
动态库中的LIB:该LIB包含了函数所在的DLL文件和文件中函数位置的信息(索引),函数实现代码由运行时加载在进程空间中的DLL提供。
备注:LIB是编译时用到的,DLL是运行时用到的。如果要完成源代码的编译,只需要LIB;如果要使动态链接的程序运行起来,只需要DLL。
3.生成和使用动态链接库
3.1生成动态链接库
创建C++ DLL工程如下,选中【导出符号】
创建工程的默认头文件如下:
//-------------------------------------------------------------------------
// 新建生成DLL工程时,选中了【导出符号】,VS默认定义了宏CREATEDLL_EXPORTS,所以
// 当CREATEDLL_EXPORTS被定义时,CREATEDLL_API用于导出;当使用DLL时,
// CREATEDLL_EXPORTS未定义,CREATEDLL_API用于导入
//-------------------------------------------------------------------------
#ifdef CREATEDLL_EXPORTS
#define CREATEDLL_API __declspec(dllexport)
#else
#define CREATEDLL_API __declspec(dllimport)
#endif
// 此类是从 CreateDLL.dll 导出的
class CREATEDLL_API CCreateDLL {
public:
CCreateDLL(void);
// TODO: 在此添加您的方法。
};
extern CREATEDLL_API int nCreateDLL;
CREATEDLL_API int fnCreateDLL(void);
默认的源文件如下:
#include "stdafx.h"
#include "CreateDLL.h"
// 这是导出变量的一个示例
CREATEDLL_API int nCreateDLL=0;
// 这是导出函数的一个示例。
CREATEDLL_API int fnCreateDLL(void)
{
return 42;
}
// 这是已导出类的构造函数。
// 有关类定义的信息,请参阅 CreateDLL.h
CCreateDLL::CCreateDLL()
{
return;
}
点击【编译】即可编译LIB和DLL文件。
3.2使用动态链接库
调用动态链接库有两种方法:隐式调用、显示调用
-
隐式调用:需要.h文件、DLL文件、LIB文件
- 将DLL放在工程的工作目录;
- 设置项目属性->VC++目录->库目录为LIB所在的路径;
- 将LIB添加到项目属性->链接器->输入->附加依赖项;(或者#pragma comment(lib, “**.lib”))
- 在源文件中添加.h文件
- 显示调用:只需要DLL文件,这种方法需要通过WIN32 API加载函数和变量,比较麻烦