目录如图:
当头文件形式写为下图#include<workManager.h>
会出现C++ 无法打开源文件的错误
而当头文件写为下图#include"workManager.h"不会报错
原因是 C++ 编译器搜索头文件的路径规则不同。
- 双引号形式(
#include"workManager.h"
):- 编译器首先会在当前源文件所在的目录中查找头文件。
- 如果没找到,才会按照系统指定的路径去查找。
- 尖括号形式(
#include<workManager.h>
):- 编译器会直接去系统指定的标准库目录、项目配置的包含目录中查找头文件。
- 它不会去当前源文件所在的目录查找。
不同形式的适用场景:
1、双引号形式:
自定义头文件:当引用项目内部的头文件(如模块间的依赖)时,推荐使用双引号。
相对路径引用:可以使用相对路径指定头文件位置,例如:
#include "utils/logger.h" // 引用当前目录下utils子目录中的文件
2、尖括号形式:
标准库头文件:引用标准库或第三方库的头文件时,必须使用尖括号。例如:
#include <iostream> // C++标准库头文件
#include <vector> // C++标准库头文件
#include <opencv2/opencv.hpp> // 第三方库OpenCV
全局包含路径:当头文件位于项目统一指定的全局包含目录中时,使用尖括号更清晰。