文档声明:
以下资料均属于本人在学习过程中产出的学习笔记,如果错误或者遗漏之处,请多多指正。并且该文档在后期会随着学习的深入不断补充完善。感谢各位的参考查看。
笔记资料仅供学习交流使用,转载请标明出处,谢谢配合。
如果存在相关知识点的遗漏,可以在评论区留言,看到后将在第一时间更新。
作者:Aliven888
第一种:#pragma comment(…) 导入
该宏放置一个注释到对象文件或者可执行文件。
格式:
#pragma comment( comment-type [lib,"commentstring"] )
关键词解析:
- comment-type: 是一个预定义的标识符,指定注释的类型,应该是compiler,exestr,lib,linker之一。
(1)compiler:放置编译器的版本或者名字到一个对象文件,该选项是被linker忽略的。
(2)exestr:在以后的版本将被取消。
(3)lib:放置一个库搜索记录到对象文件中,这个类型应该是和commentstring(指定你要Liner搜索的lib的名称和路径)这个库的名字放在Object文件的默认库搜索记录的后面,linker搜索这个库就像你在命令行输入这个命令一样。你可以在一个源文件中设置多个库记录,它们在object文件中的顺序和在源文件中的顺序一样。如果默认库和附加库的次序是需要区别的,使用Z编译开关是防止默认库放到object模块。
(4)linker:指定一个连接选项,这样就不用在命令行输入或者在开发环境中设置了。 - commentstring: 是一个提供为comment-type提供附加信息的字符串,可以是库文件的名字,也可以是库文件的路径(相对路径和绝对路径都可)。
演示实例:
#include "stdafx.h"
#include "Alivendll.h" //静态库头文件
#include <iostream>
using namespace std;
//因为我是放在工程同目录下的,所以直接写库名称即可,但是如果放在别的路径下,需要填写路径,否则不发访问
#pragma comment(lib, "Alivendll.lib")
int main()
{
AlivenTest(); //静态库封装的函数库
system("pause");
return 0;
}
第二种:在属性中配置附加依赖项
前面介绍的放在项目工程路径下进行的加载,这里我们我放在别的路径下进行演示。
第一步:根据 lib 文件放的路径,在 属性 – 连接器 – 常规 – 附加库目录 下添加当前 lib 库所在的路径(可以是相对路径,也可以是绝对路径)。
第二步:导入 lib 库文件(注意,这里不要写错了,否则程序将报错)。
第三种:直接加载到项目工程中
这种方法比较简单,而且不容易出错,如果采用这样方法的话,建议新建一个文件夹统一管理,方便维护。
直接将 lib 库文件导入到项目工程中即可。
注意事项:
1、以上三种方式,只是 lib 库的导入,如果需要使用库的库函数,都是需要导入库的头文件的(#include “Alivendll.h” //静态库头文件)。
笔记跟新记录
时间 | 内容 |
---|---|
2020-11-08 | 创建笔记 |