0

0

什么是C++中的PIMPL惯用法 减少编译依赖的实现方式

P粉602998670

P粉602998670

发布时间:2025-07-13 09:19:02

|

376人浏览过

|

来源于php中文网

原创

pimpl的基本结构是:在公开类中仅保留一个指向实现类的指针,实现类定义在源文件中。具体步骤为:1. 在头文件中前向声明实现类并声明指针成员;2. 在源文件中定义实现类的具体内容;3. 在构造函数中初始化指针,析构函数中释放资源。这种结构通过将私有实现移出头文件,有效减少了编译依赖。

什么是C++中的PIMPL惯用法 减少编译依赖的实现方式

在C++开发中,PIMPL(Pointer to IMPLementation)是一种常见的设计惯用法,主要用于隐藏类的实现细节,减少编译依赖。简单来说,它通过一个指向实现类的指针,把接口和实现分离开来,从而避免头文件改动引发的大规模重新编译。

什么是C++中的PIMPL惯用法 减少编译依赖的实现方式

什么是PIMPL的基本结构?

PIMPL的核心思想是:在一个公开的类中,只保留一个指向实际实现类的指针。这个实现类通常定义在源文件(.cpp)中,而不是头文件里。

什么是C++中的PIMPL惯用法 减少编译依赖的实现方式

举个例子:

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

// widget.h
class Widget {
public:
    Widget();
    ~Widget();
private:
    class Impl; // 前向声明
    Impl* pImpl;
};
// widget.cpp
class Widget::Impl {
    // 实现细节
};

Widget::Widget() : pImpl(new Impl) {}
Widget::~Widget() { delete pImpl; }

这样做的好处很明显:如果修改了Impl的内容,只需要重新编译.cpp文件,不需要重新编译所有包含widget.h的地方。

什么是C++中的PIMPL惯用法 减少编译依赖的实现方式

PIMPL如何帮助减少编译依赖?

当一个头文件被多个源文件包含时,只要这个头文件有改动,所有引用它的文件都要重新编译。这在大型项目中会导致构建时间显著增加。

使用PIMPL后,这些潜在的“连锁反应”可以被有效控制,因为:

BlessAI
BlessAI

Bless AI 提供五个独特的功能:每日问候、庆祝问候、祝福、祷告和名言的文本生成和图片生成。

下载
  • 所有私有成员变量都被移到了实现文件中。
  • 类的内部结构变化不会影响到外部代码。
  • 头文件变得简洁,依赖项更少。

比如,如果你在类中添加了一个新的私有成员函数或变量,原本可能需要重新编译整个项目,但用了PIMPL之后,只需要重新编译对应的.cpp文件。


使用PIMPL需要注意的问题

虽然PIMPL有很多优点,但在使用时也有一些细节需要注意:

  • 内存分配开销:每次构造对象时都需要动态分配内存给pImpl,可能会带来一定的性能损耗。可以通过自定义内存池或者使用std::unique_ptr结合自定义删除器来优化。
  • 必须手动编写析构函数:由于使用了原始指针或智能指针管理资源,不能依赖编译器生成的析构函数,否则可能导致未定义行为。
  • 访问效率略有下降:每次访问实现类的成员都要通过指针间接访问,虽然现代编译器优化得很好,但在性能敏感场景下还是要注意。

此外,在C++11以后,推荐使用std::unique_ptr代替裸指针,以更好地管理资源:

// widget.h
#include 
class Widget {
public:
    Widget();
    ~Widget();
private:
    struct Impl;
    std::unique_ptr pImpl;
};

这样可以自动处理内存释放问题,也更符合现代C++的写法。


什么时候适合使用PIMPL?

PIMPL不是万能的,更适合以下几种情况:

  • 接口稳定、实现经常变动的类。
  • 被广泛使用的公共头文件,希望减少其变更带来的影响。
  • 构建速度成为瓶颈的大型项目。

而在小型项目或对性能要求极高的场合,PIMPL带来的间接性可能反而显得多余。


基本上就这些。PIMPL是一个实用但容易被忽略的技术点,掌握好它可以在实际开发中提升不少效率。

相关专题

更多
硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1017

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

62

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

400

2025.12.29

Java 桌面应用开发(JavaFX 实战)
Java 桌面应用开发(JavaFX 实战)

本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

36

2026.01.14

php与html混编教程大全
php与html混编教程大全

本专题整合了php和html混编相关教程,阅读专题下面的文章了解更多详细内容。

18

2026.01.13

PHP 高性能
PHP 高性能

本专题整合了PHP高性能相关教程大全,阅读专题下面的文章了解更多详细内容。

34

2026.01.13

MySQL数据库报错常见问题及解决方法大全
MySQL数据库报错常见问题及解决方法大全

本专题整合了MySQL数据库报错常见问题及解决方法,阅读专题下面的文章了解更多详细内容。

19

2026.01.13

PHP 文件上传
PHP 文件上传

本专题整合了PHP实现文件上传相关教程,阅读专题下面的文章了解更多详细内容。

16

2026.01.13

PHP缓存策略教程大全
PHP缓存策略教程大全

本专题整合了PHP缓存相关教程,阅读专题下面的文章了解更多详细内容。

6

2026.01.13

热门下载

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

精品课程

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

共94课时 | 6.7万人学习

C 教程
C 教程

共75课时 | 4万人学习

C++教程
C++教程

共115课时 | 12.2万人学习

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

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