CPlusPlusThings/codingStyleIdioms/5_pImpl/README.md
Light-City 4f149eec72 update
2019-12-12 16:09:55 +08:00

57 lines
2.0 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

# C++惯用法之pImpl
“指向实现的指针”或“pImpl”是一种 C++ 编程技巧,它将类的实现细节从对象表示中移除,放到一个分离的类中,并以一个不透明的指针进行访问。
使用pImpl惯用法的原因如下
考虑如下例子:
```cpp
class X
{
private:
C c;
D d;
} ;
```
变成pImpl就是下面这样子
```cpp
class X
{
private:
struct XImpl;
XImpl* pImpl;
};
```
CPP定义
```cpp
struct X::XImpl
{
C c;
D d;
};
```
- 二进制兼容性
开发库时可以在不破坏与客户端的二进制兼容性的情况下向XImpl添加/修改字段(这将导致崩溃!)。 由于在向Ximpl类添加新字段时X类的二进制布局不会更改因此可以安全地在次要版本更新中向库添加新功能。
当然您也可以在不破坏二进制兼容性的情况下向X / XImpl添加新的公共/私有非虚拟方法,但这与标准的标头/实现技术相当。
- 数据隐藏
如果您正在开发一个库,尤其是专有库,则可能不希望公开用于实现库公共接口的其他库/实现技术。 要么是由于知识产权问题,要么是因为您认为用户可能会被诱使对实现进行危险的假设,或者只是通过使用可怕的转换技巧来破坏封装。 PIMPL解决/缓解了这一难题。
- 编译时间
编译时间减少了因为当您向XImpl类添加/删除字段和/或方法时(仅映射到标准技术中添加私有字段/方法的情况仅需要重建X的源实现文件。 实际上,这是一种常见的操作。
使用标准的标头/实现技术没有PIMPL当您向X添加新字段时曾经重新分配X在堆栈或堆上的每个客户端都需要重新编译因为它必须调整分配的大小 。 好吧每个从未分配X的客户端也都需要重新编译但这只是开销客户端上的结果代码是相同的
> https://stackoverflow.com/questions/8972588/is-the-pimpl-idiom-really-used-in-practices