0

0

C++如何避免头文件被重复包含_C++头文件保护宏与#pragma once用法

裘德小鎮的故事

裘德小鎮的故事

发布时间:2025-11-17 18:50:02

|

996人浏览过

|

来源于php中文网

原创

使用头文件保护宏或#pragma once可防止C++头文件重复包含。前者通过#ifndef、#define和#endif定义唯一宏来避免重复编入,兼容性好;后者为编译器指令,写法简洁且高效,但非ISO标准。推荐根据项目需求选择:注重可移植性时用保护宏,现代开发中多用#pragma once。

c++如何避免头文件被重复包含_c++头文件保护宏与#pragma once用法

在C++开发中,头文件被重复包含是一个常见问题。如果一个头文件被多次包含到同一个编译单元中,可能导致类、函数或变量的重复定义,从而引发编译错误。为了解决这个问题,通常有两种主流方法:使用头文件保护宏(include guards)和 #pragma once 指令。

头文件保护宏(Include Guards)

这是传统的、可移植性强的方法,通过预处理器指令防止头文件内容被多次处理。

基本写法如下:

#ifndef MY_HEADER_H
#define MY_HEADER_H

// 头文件内容
class MyClass {
    // ...
};

#endif // MY_HEADER_H

说明:

立即学习C++免费学习笔记(深入)”;

  • #ifndef 判断某个宏是否未定义。如果未定义,则继续执行下面的内容。
  • #define 定义一个唯一的宏名,通常根据项目和文件命名规则来命名,避免冲突。
  • 当该头文件第一次被包含时,宏未定义,因此会定义宏并包含内容;第二次及以后再包含时,宏已定义,#ifndef 条件为假,整个头文件内容被跳过。

优点:

  • 兼容所有标准C++编译器。
  • 符合ISO C++标准,可移植性好。

注意事项:

  • 宏名称必须唯一,建议使用全大写、下划线分隔,并包含项目或文件信息,例如:GRAPHICS_CAMERA_H
  • 避免使用保留标识符(如双下划线或以_开头后接大写字母)。

#pragma once 的用法

这是一种非标准但被广泛支持的简化方式,告诉编译器只允许该头文件被包含一次。

PictoGraphic
PictoGraphic

AI驱动的矢量插图库和插图生成平台

下载
#pragma once

// 头文件内容
class Utility {
    // ...
};

说明:

立即学习C++免费学习笔记(深入)”;

  • #pragma once 是编译器指令,由大多数现代编译器(如GCC、Clang、MSVC)支持。
  • 无需手动定义宏,更简洁,也减少了命名冲突的风险。

优点:

  • 写法简单,不易出错。
  • 编译器可优化处理,有时比宏判断更快。

缺点:

  • 不是C++标准的一部分,理论上存在可移植性风险(尽管实际中极少遇到不支持的情况)。
  • 在某些特殊情况下(如硬链接或符号链接指向同一文件),可能判断失效。

两种方式如何选择?

目前主流做法是:

  • 在个人项目或现代开发环境中,推荐使用 #pragma once,简洁清晰。
  • 在需要最大可移植性或参与开源项目时,使用传统 include guards 更稳妥。
  • 有些人会同时使用两者作为“双重保险”,但这通常没有必要。

示例混合写法(少见但安全):

#pragma once
#ifndef UTILITY_H
#define UTILITY_H

// 内容

#endif

基本上就这些。无论选择哪种方式,关键是确保每个头文件都有防重包含机制。#pragma once 更现代便捷,而 include guards 更标准可靠。根据团队规范和项目需求选择即可。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
typedef和define区别
typedef和define区别

typedef和define区别在类型检查、作用范围、可读性、错误处理和内存占用等。本专题为大家提供typedef和define相关的文章、下载、课程内容,供大家免费下载体验。

109

2023.09.26

define的用法
define的用法

define用法:1、定义常量;2、定义函数宏:3、定义条件编译;4、定义多行宏。更多关于define的用法的内容,大家可以阅读本专题下的文章。

338

2023.10.11

mysql标识符无效错误怎么解决
mysql标识符无效错误怎么解决

mysql标识符无效错误的解决办法:1、检查标识符是否被其他表或数据库使用;2、检查标识符是否包含特殊字符;3、使用引号包裹标识符;4、使用反引号包裹标识符;5、检查MySQL的配置文件等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

183

2023.12.04

Python标识符有哪些
Python标识符有哪些

Python标识符有变量标识符、函数标识符、类标识符、模块标识符、下划线开头的标识符、双下划线开头、双下划线结尾的标识符、整型标识符、浮点型标识符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

287

2024.02.23

java标识符合集
java标识符合集

本专题整合了java标识符相关内容,想了解更多详细内容,请阅读下面的文章。

258

2025.06.11

c++标识符介绍
c++标识符介绍

本专题整合了c++标识符相关内容,阅读专题下面的文章了解更多详细内容。

124

2025.08.07

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

24

2026.01.28

包子漫画在线官方入口大全
包子漫画在线官方入口大全

本合集汇总了包子漫画2026最新官方在线观看入口,涵盖备用域名、正版无广告链接及多端适配地址,助你畅享12700+高清漫画资源。阅读专题下面的文章了解更多详细内容。

7

2026.01.28

ao3中文版官网地址大全
ao3中文版官网地址大全

AO3最新中文版官网入口合集,汇总2026年主站及国内优化镜像链接,支持简体中文界面、无广告阅读与多设备同步。阅读专题下面的文章了解更多详细内容。

28

2026.01.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 7.8万人学习

C 教程
C 教程

共75课时 | 4.3万人学习

C++教程
C++教程

共115课时 | 14.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号