c/c++头文件,保存,备用

本文介绍了C++标准库中的关键头文件,包括传统C++和标准C++的不同部分,涵盖了从基本输入输出到复杂数据结构和算法的各种功能。同时提到了C99新增的内容及其对计算机硬件和编译器技术的改进。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 
C、传统 C++
#include <stdio.h>     //定义输入/输出函数
#include <stdlib.h>    //定义杂项函数及内存分配函数
#include <string.h>    //字符串处理
#include <assert.h>    //设定插入点
#include <ctype.h>     //字符处理
#include <errno.h>     //定义错误码
#include <float.h>     //浮点数处理
#include <fstream.h>    //文件输入/输出
#include <iomanip.h>    //参数化输入/输出
#include <iostream.h>   //数据流输入/输出
#include <limits.h>    //定义各种数据类型最值常量
#include <locale.h>    //定义本地化函数
#include <math.h>     //定义数学函数
#include <strstrea.h>   //基于数组的输入/输出
#include <time.h>     //定义关于时间的函数
#include <wchar.h>     //宽字符处理及输入/输出
#include <wctype.h>    //宽字符分类

 

///////////////////////////////////////////////////////////


标准 C++ 
#include <algorithm>    //STL 通用算法
#include <bitset>     //STL 位集容器
#include <cctype>
#include <cerrno>
#include <clocale>
#include <cmath>
#include <complex>     //复数类
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <ctime>
#include <deque>      //STL 双端队列容器
#include <exception>    //异常处理类
#include <fstream>
#include <functional>   //STL 定义运算函数(代替运算符)
#include <limits>
#include <list>      //STL 线性列表容器
#include <map>       //STL 映射容器
#include <iomanip>
#include <ios>       //基本输入/输出支持
#include <iosfwd>     //输入/输出系统使用的前置声明
#include <iostream>
#include <istream>     //基本输入流
#include <ostream>     //基本输出流
#include <queue>      //STL 队列容器
#include <set>       //STL 集合容器
#include <sstream>     //基于字符串的流
#include <stack>      //STL 堆栈容器    
#include <stdexcept>    //标准异常类
#include <streambuf>    //底层输入/输出支持
#include <string>     //字符串类
#include <utility>     //STL 通用模板类
#include <vector>     //STL 动态数组容器
#include <cwchar>
#include <cwctype>

using namespace std;

//////////////////////////////////////////////////////////////////////////

C99 增加

#include <complex.h>   //复数处理
#include <fenv.h>    //浮点环境
#include <inttypes.h>  //整数格式转换
#include <stdbool.h>   //布尔环境
#include <stdint.h>   //整型环境
#include <tgmath.h>   //通用类型数学宏

 

//

C99 is a modern dialect of the C programming language. It extends the previous version (C89) to make better use of available computer hardware and to better employ the latest advances in compiler technology.

 

#include <assert h>     设定插入点 #include <ctype h>     字符处理 #include <errno h>     定义错误码 #include <float h>     浮点数处理 #include <fstream h>    文件输入/输出 #include <iomanip h>    参数化输入/输出 #include <iostream h>    数据流输入/输出 #include <limits h>     定义各种数据类型最值常量 #include <locale h>     定义本地化函数 #include <math h>      定义数学函数 #include <stdio h>     定义输入/输出函数 #include <stdlib h>     定义杂项函数及内存分配函数 #include <string h>     字符串处理 #include <strstrea h>    基于数组的输入/输出 #include <time h>      定义关于时间的函数 #include <wchar h>     宽字符处理及输入/输出 #include <wctype h>     宽字符分类 int spawnvpe int mode char pathname char argv[] char envp[] spawn函数族在mode模式下运行子程序pathname 并将参数 arg0 arg1 arg2 argv[] envp[] 传递给子程序 出错返回 1 mode为运行模式 mode为 P WAIT 表示在子程序运行完后返回本程序 P NOWAIT 表示在子程序运行时同时运行本程序 不可用 P OVERLAY表示在本程序退出后运行子程序 在spawn函数族中 后缀l v p e添加到spawn后 所指定的函数将具有某种操作能力 有后缀 p时 函数利用DOS的PATH查找子程序文件 l时 函数传递的参数个数固定 v时 函数传递的参数个数不固定 ">#include <assert h>     设定插入点 #include <ctype h>     字符处理 #include <errno h>     定义错误码 #include <float h>     浮点数处理 #include <fstream h>    文件输入/输出 #include <iomanip h& [更多]
<think>好的,我现在需要帮助用户解决在Keil中添加头文件的问题。用户之前提到过重装Keil后出现路径错误,以及添加头文件时的各种问题,比如路径不正确、头文件重复等。现在他想知道如何正确添加和使用头文件。首先,我得回忆一下Keil的配置流程,然后结合引用中的信息,整理出步骤。 首先,用户可能需要添加自定义的头文件路径。根据引用[1],用户需要进入Options for Target的C51或C/C++标签页,添加包含头文件的目录。这一步是关键,因为Keil在编译时会搜索这些路径来找头文件。如果路径错误,就会提示找不到文件。 然后,用户可能自己创建了头文件,需要正确放置。引用[2]中提到,有时候直接在项目中添加现有文件可能有问题,所以在软件内新建文件夹,并保存.c和.h文件到那里,再添加路径。这可能适用于项目结构混乱的情况,需要保持文件结构的清晰。 另外,引用[3]提到了使用符号链接的方法,将头文件链接到编译器路径下。不过这可能对普通用户来说有点复杂,但可以作为备用方案,特别是当用户不想移动头文件位置时。 还有引用[4]中的例子,遇到头文件重名的问题,导致编译器引用了错误的文件。这时候需要指定相对路径或调整包含顺序。所以在添加头文件路径时,要注意顺序,避免同名文件冲突。 接下来,我需要把这些信息整合成清晰的步骤。首先,添加头文件路径,然后是检查重复头文件,接着是正确引用自定义头文件,最后验证配置。可能还需要提到常见问题,比如路径是否正确、大小写敏感、包含顺序等。 用户可能需要具体的操作步骤,比如如何在Keil的界面中找到Options for Target,哪个标签页下添加路径,是否需要重启或重新编译。另外,示例代码中的#include指令应该用双引号还是尖括号,这点需要说明,双引号用于用户自定义头文件,优先在当前目录和指定路径搜索。 还要注意,如果用户重装Keil,之前的项目可能仍然指向旧路径,需要更新为新的安装路径下的头文件路径,如引用[1]中的例子,用户将路径改为D:\Keil5\C51\INC\Atmel,解决了问题。 最后,常见问题部分需要涵盖路径错误、重名文件、符号链接的使用,以及头文件编写规范,比如防止重复包含的#ifndef宏。这些都能帮助用户避免常见错误。</think>在Keil中正确添加和使用头文件(.h)需要遵循以下步骤,结合工程配置和文件管理规范: ### 一、添加头文件路径 1. **打开工程配置** 右键点击Target → 选择`Options for Target` → 切换到`C/C++`(ARM开发)或`C51`(51单片机开发)标签页。 2. **配置包含路径** 在`Include Paths`栏点击右侧`...`按钮 → 添加头文件所在目录(如`D:\Project\inc`)。 *支持多级目录添加,路径分隔符用`\`或`/`均可*[^1][^4]。 3. **验证路径优先级** 通过调整路径列表顺序控制同名头文件的加载优先级,避免因路径冲突导致错误引用[^4]。 --- ### 二、引用自定义头文件 1. **编写头文件** 使用`#ifndef`宏防止重复包含: ```c // my_header.h #ifndef __MY_HEADER_H__ #define __MY_HEADER_H__ // 声明或定义内容 #endif ``` 2. **在代码中引用** 使用双引号优先从工程目录搜索: ```c #include "my_header.h" // 自定义头文件 #include <stdint.h> // 系统头文件 ``` --- ### 三、特殊场景处理 1. **头文件重名冲突** 若存在同名头文件(如`timers.h`),采用相对路径精确指定: ```c #include "FreeRTOS/include/timers.h" // 替代原#include "timers.h"[^4] ``` 2. **跨平台符号链接** 通过`mklink`创建虚拟路径(需管理员权限): ```bat mklink "D:\Keil\C51\INC\custom.h" "E:\实际路径\custom.h"[^3] ``` --- ### 四、验证配置 1. **编译检查** 执行`Rebuild`后,在`Build Output`窗口观察: - 若提示`..\REGX52.H contains an incorrect path`:检查路径拼写和斜杠方向[^1] - 若报`undefined identifier`:确认头文件内容是否正确定义了相关符号[^4] 2. **预处理器检查** 在`Options for Target → Listing → C Preprocessor Listing`中查看展开后的头文件内容。 --- ### 常见问题解决方案 | 问题现象 | 解决方法 | |---------|----------| | 头文件路径正确但提示未找到 | 检查路径是否包含中文字符/特殊符号[^2] | | 修改头文件后编译未生效 | 清理工程(`Project → Clean Targets`)后重新编译 | | 多版本编译器冲突 | 在`Manage Project Items`中确认使用的工具链版本 |
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值