查看原文
其他

#include使用引号“”和尖括号<>的区别?

关注+星标公众,不错过精彩内容

编排 | strongerHuang

微信公众号 | 嵌入式专栏


很多程序员写代码,可能没有仔细研究过#include相关的内容,下面就来简单说说。


嵌入式专栏

1

关于#include


首先,#include为预处理语句,那么什么是预处理语句呢?


预处理语句最明显的标志是一些行首以#开始的特殊语句。


例如:#include、 #define、 #if等就是预处理语句。在程序的其它编译处理(词法分析、语法分析、代码生成、优化和连接等)之前,先进行这些语句的分析处理。 


在编译工具中,有一个叫预处理器,预处理器发现 #include 指令后,就会进行一些预处理操作。


嵌入式专栏

2

#include的定义


如果你在看一些C/C++教程,那么你可能会发现,有些教程涨的#include命令写作#include <文件名>,但有时候又会出现#include "文件名"


你会很疑惑,到底哪个是对的呢?为什么要有这两种不同的写法呢?


1.#include <xxx.h> 

系统自带的头文件用尖括号括起来,这样编译器会在系统文件目录下查找。 


2.#include "xxx.h"

用户自定义的文件用双引号括起来,编译器首先会在用户目录下查找,然后在到C++安装目录(比如VC中可以指定和修改库文件查找路径,Unix和Linux中可以通过环境变量来设定)中查找,最后在系统文件中查找。 


这两种写法都是正确的写法,但是它们却是有区别的。我们知道C/C++已经有一些编写好的头文件(比如标准函数库等),它们存放在VC++的Include文件夹里。当我们使用#include <文件名>命令时,编译器就到这个文件夹里去找对应的文件。显然,用这种写法去包含一个我们自己编写的头文件(不在那个Include文件夹里)就会出错了。所以包含C++提供的头文件时,应该使用尖括号。


相反地,#include "文件名"命令则是先在当前文件所在的目录搜索是否有符合的文件,如果没有再到Include文件夹里去找对应的文件。因此,无论这个文件是C++提供的还是自己编写的,使用#include "文件名"命令一定是正确的。这也正是书中本节之前的程序一律使用#include "文件名"命令的原因。


嵌入式专栏

1

关于标准的尖括号


C++标准中,包含C++提供的头文件并不是写作#include <文件名>,如#include <iostream.h>的写法是过时的。正确的写法是#include <iostream>,并且要使用std名字空间。有些程序中会有using namespace std;就是按照这种标准书写的。名字空间也称为命名空间,主要是用来避免大型程序开发中的标志符冲突。标准还规定了如何在C++中包含C的头文件,有兴趣的读者可以到网上查阅这些资料。


尽管以上两种#include命令都可以正确地被VC++识别了,但是它们却并不符合C++的标准。标准规定,包含C++提供的标准头文件或系统头文件时应使用尖括号,包含自定义头文件时可使用双引号。 


虽然有些文件是系统文件,但如果你工程中包含有相应文件,使用#include "xxx.h" 也不会报错(比如在Keil中使用#include "stdio.h"),但还是建议使用规范的代码。


可能复制粘贴习惯了,你都不知道究竟是 #include <xxx.h> 还是 #include "xxx.h" 了。


免责声明:本文素材来源网络,版权归原作者所有。如涉及作品版权问题,请与我联系删除。

------------ END ------------


后台回复『嵌入式C语言』阅读更多相关文章。

关注微信公众号『嵌入式专栏』,底部菜单查看更多内容,回复“加群”按规则加入技术交流群。


点击“阅读原文”查看更多分享,欢迎点分享、收藏、点赞、在看

您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存