#pragma

有时候程序会出现无法解析的情况

error LNK2019: 无法解析的外部符号 __imp__SetupDiGetClassDevsA@16

当我加入#pragma comment(lib, "setupapi.lib")后,不再出现错误


pragma comment(...)
该指令将一个注释记录放入一个对象文件或 可执行文件中。
常用的lib关键字,可以帮我们连入一个 库文件


#pragma comment( comment-type ,["commentstring"] )
comment-type是一个预定义的 标识符,指定注释的类型,应该是compiler,exestr,lib,linker之一。
commentstring是一个提供为comment-type提供附加信息的字符串。
lib:
放置一个库搜索记录到对象文件中,这个类型应该是和commentstring(指定你要Linker搜索的lib的名称和路径)
这个库的名字放在Object文件的默认库搜索记录的后面,linker搜索这个这个库就像你在命令行输入这个命令一样。
你可以在一个 源文件中设置多个库记录,它们在object文件中的顺序和在源文件中的顺序一样。
如果默认库和附加库的次序是需要区别的,使用Z编译开关是防止默认库放到object模块。


至于为什么有了头文件还需要这样做才能解决问题,我查了下资料,都没有找到确切的答案,我猜想lib文件没有放在
指定的地方,就好像是每次配置环境时,要考虑环境路径之类的来指定搜索路径。

### C/C++ 预处理器指令 `#pragma` 与 `#pragma once` #### `#pragma` 概述 `#pragma` 是一个通用的关键字,用于向编译器传递特殊的信息或改变编译行为。其具体功能依赖于参数的不同而变化。例如,可以用来设置结构体成员的对齐方式: ```cpp #pragma pack(push, 1) // 设置结构体的字节对齐方式为1字节 struct MyData { int labeledValue; float observation; }; #pragma pack(pop) ``` 这种情况下,`#pragma` 能够确保数据按照指定的方式排列,从而节省内存空间或者满足硬件接口的要求[^4]。 #### `#pragma once` 特定用途 相比之下,`#pragma once` 则专门用于防止头文件被多次包含。当编译器遇到此命令时会记录下该文件路径;如果后续再次尝试引入相同路径下的文件,则会被忽略处理。这种方式简单直观,易于理解和维护: ```cpp #pragma once // 文件其余部分... ``` 这种方法不仅提高了代码清晰度还减少了因条件宏定义带来的复杂性[^1]。 #### 条件编译对比 (`#ifndef/#define/#endif`) 传统上为了避免重复包含问题常采用如下模式: ```cpp #ifndef _HEADER_GUARD_ #define _HEADER_GUARD_ // 头文件内容... #endif //_HEADER_GUARD_ ``` 虽然也能达到目的,但相比起简洁明了的 `#pragma once` 显得冗长繁琐一些。不过值得注意的是,并不是所有的编译环境都支持 `#pragma once` ,所以在追求跨平台兼容性的项目里可能仍需沿用旧方法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值