0

0

c++头文件怎么写 c++ .h与.cpp分离编写【技巧】

尼克

尼克

发布时间:2026-01-08 13:35:02

|

440人浏览过

|

来源于php中文网

原创

C++头文件应加include guard或#pragma once防重复包含,只声明类、函数、extern变量等接口,不放实现;const和inline内容可安全放入头文件;.cpp专注实现并精简包含。

c++头文件怎么写 c++ .h与.cpp分离编写【技巧】

头文件(.h)负责声明,源文件(.cpp)负责实现——这是 C++ 分离编写的底层逻辑。写错头文件,轻则重复定义报错,重则链接失败或行为异常。核心就三点:防重复包含、声明与定义分离、接口清晰。

头文件必须加 include guard 或 #pragma once

没有防护的头文件一旦被多个 .cpp 包含,就会导致符号重定义。推荐用 #pragma once(简洁、主流编译器都支持),也可用传统宏卫士:

  • #ifndef MYCLASS_H
  • #define MYCLASS_H
  • /* 类声明、函数声明、extern 变量声明等 */
  • #endif // MYCLASS_H

注意:宏名要唯一,一般用大写文件名+下划线(如 VECTOR_H),避免用 _ 开头(C++ 标准保留)。

头文件里只放“能被别人看到”的东西

声明是给使用者看的契约,不是实现细节。以下可以放:

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

Poly.ai
Poly.ai

AI电话语音服务助手,接听电话并自动回复客户。

下载
  • 类定义(含 public/private 成员声明、构造/析构/成员函数声明)
  • 函数声明(不写函数体,例如 void print();
  • extern 全局变量声明(extern int g_count;
  • using 声明(如 using std::string;),但慎用,避免污染全局命名空间
  • 模板定义(模板必须在头文件中实现,因为编译器需要看到完整定义才能实例化)

以下绝对不能放

  • 函数定义(除非是 inline 或 constexpr)
  • 非 const 全局变量定义(会引发 ODR 违规)
  • 静态局部变量、static 函数定义
  • main() 函数

.cpp 文件专注实现,且只包含真正需要的头

每个 .cpp 应包含对应的 .h(如 MyClass.cpp 包含 "MyClass.h"),再按需引入标准库或其他依赖头。不要在 .h 里无脑 #include 大量头文件——那会拖慢所有包含它的编译速度。

  • 优先用前向声明(class OtherClass;)替代 #include,尤其当只需要指针/引用时
  • 把只在 .cpp 内部用到的头(如 stream>)移到 .cpp 里,不放进 .h
  • 实现成员函数时,类作用域写法更清晰:void MyClass::doSomething() { ... }

const 变量和 inline 函数可安全放在头文件中

全局 const 变量默认具有内部链接(internal linkage),所以 const int MAX_SIZE = 100; 放头文件不会冲突;inline 函数同理(编译器保证只有一份实例)。但要注意:

  • 如果想让 const 变量有外部链接(供其他文件取地址),得显式加 extern const int MAX_SIZE; 声明在 .h,再在某个 .cpp 中定义
  • constexpr 变量天然内联,适合放头文件,也推荐用于代替宏常量

不复杂但容易忽略

相关专题

更多
python中print函数的用法
python中print函数的用法

python中print函数的语法是“print(value1, value2, ..., sep=' ', end=' ', file=sys.stdout, flush=False)”。本专题为大家提供print相关的文章、下载、课程内容,供大家免费下载体验。

184

2023.09.27

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

315

2023.08.02

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1463

2023.10.24

typedef和define区别
typedef和define区别

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

107

2023.09.26

define的用法
define的用法

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

324

2023.10.11

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

520

2023.09.20

全局变量怎么定义
全局变量怎么定义

本专题整合了全局变量相关内容,阅读专题下面的文章了解更多详细内容。

73

2025.09.18

python 全局变量
python 全局变量

本专题整合了python中全局变量定义相关教程,阅读专题下面的文章了解更多详细内容。

96

2025.09.18

Golang 分布式缓存与高可用架构
Golang 分布式缓存与高可用架构

本专题系统讲解 Golang 在分布式缓存与高可用系统中的应用,涵盖缓存设计原理、Redis/Etcd集成、数据一致性与过期策略、分布式锁、缓存穿透/雪崩/击穿解决方案,以及高可用架构设计。通过实战案例,帮助开发者掌握 如何使用 Go 构建稳定、高性能的分布式缓存系统,提升大型系统的响应速度与可靠性。

27

2026.01.09

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

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

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