前端学习C++之:.h(.hpp)与.cpp文件

以JavaScript前端开发者的角度理解C++中的文件扩展名

1. 基本概念对比

C++文件 JavaScript对比 作用
.h / .hpp interface 或 types.d.ts 声明文件(告诉别人有什么)
.cpp .js 或 .ts 实现文件(具体怎么做)

2. 文件类型详解

.h 和 .hpp 文件 = 头文件 (Header Files)

  • 作用:声明类、函数、变量的"接口"
  • 类比:JavaScript的 .d.ts 文件或 interface 声明
  • 内容:类的声明、函数签名、常量定义
  • 例子:BoxHelper.hpp 声明了 BoxHelper 类有哪些方法

.cpp 文件 = 源文件 (Source Files)

  • 作用:实现头文件中声明的具体功能
  • 类比:JavaScript的 .js/.ts 文件
  • 内容:函数的具体实现、类方法的代码
  • 例子:BoxHelper.cpp 实现了 BoxHelper 类方法的具体逻辑

.h vs .hpp 区别

  • .h = 传统C风格头文件,可能包含C代码
  • .hpp = 明确表示C++头文件,纯C++代码
  • 功能基本相同,.hpp更现代化

3. JavaScript vs C++ 文件组织:

JavaScript (单文件模式):

js 复制代码
├── BoxHelper.js     // 声明+实现都在一个文件
└── PlaneHelper.js   // 声明+实现都在一个文件

C++ (分离模式):

cpp 复制代码
├── BoxHelper.hpp    // 只有声明 (告诉别人有什么)
├── BoxHelper.cpp    // 只有实现 (具体怎么做)
├── PlaneHelper.hpp  // 只有声明
└── PlaneHelper.cpp  // 只有实现

4. 示例展示

BoxHelper.hpp (头文件/声明) - "菜单" 📋

cpp 复制代码
class BoxHelper {
public:
    void update();     // 声明方法
    std::string type();// 声明方法
    static create(...);// 声明方法
};                            

告诉别人:"我有这些功能可以用"

BoxHelper.cpp (源文件/实现) - "厨房" 👨‍🍳

cpp 复制代码
void BoxHelper::update() {
    // 计算盒子的8个顶点坐标
    // 更新几何体数据
    // 50多行具体实现代码...
}

std::string BoxHelper::type() {
    return "BoxHelper";
}

告诉别人:"具体怎么实现这些功能"

如果用JavaScript,会是这样:

ts 复制代码
// TypeScript接口文件 (类似.hpp)
interface IBoxHelper {
    update(): void;
    type(): string;  
}
ts 复制代码
// JavaScript实现文件 (类似.cpp)
class BoxHelper implements IBoxHelper {
    update() {
        // 具体实现...
    }
    type() {
        return "BoxHelper";
    }
}

5.总结

简单记忆

text 复制代码
.hpp文件 = "合同"     → 写明有什么功能(声明)
.cpp文件 = "工厂"     → 具体怎么制造(实现)  
#include = "引用合同" → 告诉编译器我要用什么

实际工作流程

  1. 开发者写.hpp → 定义接口("我要做什么")
  2. 开发者写.cpp → 实现功能("我怎么做")
  3. 其他人用时 → 只需看.hpp就知道怎么调用
  4. 编译器 → 把所有.cpp编译链接在一起

为什么JavaScript没有这种分离

  • JavaScript是解释型语言 → 运行时才执行,不需要预编译
  • C++是编译型语言 → 需要先编译成机器码,分离可以提升编译效率

这种设计让C++项目能够:

  • 快速编译(只编译修改的部分)
  • 清晰组织(接口和实现分离)
  • 稳定接口(头文件不变,实现可以优化)
相关推荐
东东2334 分钟前
前端开发中如何取消Promise操作
前端·javascript·promise
掘金安东尼10 分钟前
官方:什么是 Vite+?
前端·javascript·vue.js
柒崽11 分钟前
ios移动端浏览器,vh高度和页面实际高度不匹配的解决方案
前端
相偎13 分钟前
用观察者模式通知UI刷新数据
c++
渣哥27 分钟前
你以为 Bean 只是 new 出来?Spring BeanFactory 背后的秘密让人惊讶
javascript·后端·面试
CoderCodingNo31 分钟前
【GESP】C++四级真题 luogu-B4040 [GESP202409 四级] 黑白方块
开发语言·c++
烛阴36 分钟前
为什么游戏开发者都爱 Lua?零基础快速上手指南
前端·lua
大猫会长1 小时前
tailwindcss出现could not determine executable to run
前端·tailwindcss
Moonbit1 小时前
MoonBit Pearls Vol.10:prettyprinter:使用函数组合解决结构化数据打印问题
前端·后端·程序员
533_1 小时前
[css] border 渐变
前端·css