侵入式智能指针和非侵入式智能指针

一直有个疑问,为什么chromium代码没有使用shared_ptr呢?

在这里讨论:https://groups.google.com/a/chromium.org/g/cxx/c/aT2wsBLKvzI

不过我在这里找到了一个简单的答案:
https://groups.google.com/a/chromium.org/g/chromium-dev/c/hgQPkvSmYlE?pli=1

1、 scoped_refptr是一种侵入式的智能指针。

2、 因为chromium不鼓励使用智能指针,所以也不希望任何类型都可以使用引用计数,所以只针对需要引用计数的类型来使用scoped_refptr。(如果引入了shared_ptr,那么任何类型都可以使用引用计数了)

3、 性能稍微好一点

对于侵入式和非侵入式智能指针,我第一次听说,所以查资料学习了下:invasive vs non-invasive ref-counted pointers in C++ - Stack Overflow

简单来总结一下:

侵入式智能指针:

1、 计数器嵌入在对象内部;

2、 需要自己确保线程安全(不是必须的);

3、 引用计数不可能在对象生命周期之外存在,所以也就没有所谓的weakptr了。

典型的侵入式智能指针代码像COM智能指针:CComPtr

或者是上面文章给出的boost::intrusive_ptr:intrusive_ptr - 1.42.0

再有就是chromium中的 scoped_refptr:https://chromium.googlesource.com/chromium/src/+/master/base/memory/scoped_refptr.h

非侵入式智能指针:

典型的就是std::shared_ptr,他的引用计数不用对象来保存(比如std::shared_ptr<MyClass> my_class中,MyClass类中没有引用计数)。

他的引用计数是在类shared_ptr中保存,在堆上申请,在所有shared_ptr实例中共享。

既然他的引用计数不在MyClass对象上保存,所以MyClass析构了,引用计数还可以保存下来,这就可以非常简单的实现weak_ptr来确保没有循环引用。

但是这个在侵入式智能指针就不行了,因为MyClass析构以后,引用计数也析构了。

侵入式 vs. 非侵入式:

侵入式的好处:计数器和对象内存是在一起的,不需要两个堆内存

侵入式的坏处:需要小心循环引用的问题,主要原因是引用计数在对象内部保存,对象销毁了引用计数也就没有了,不容易实现像std::weak_ptr的对std::shared_ptr引用计数的感知。

非侵入式的好处:使用起来比较简单,对任何类型都可以支持,使用weak_ptr很好的解决了循环引用问题

非侵入式的坏处:引用计数和对象一般是分离的,需要两次申请,不过如果使用std::make_shared(...)可以优化在一起。

参考文档:
关于侵入式和非侵入式_侵入式指针-CSDN博客

https://www.cnblogs.com/cswuyg/archive/2013/03/05/2943648.html

相关推荐
胖大和尚几秒前
clang 编译器怎么查看在编译过程中做了哪些优化
c++·clang
钱彬 (Qian Bin)1 小时前
一文掌握Qt Quick数字图像处理项目开发(基于Qt 6.9 C++和QML,代码开源)
c++·开源·qml·qt quick·qt6.9·数字图像处理项目·美观界面
双叶8362 小时前
(C++)学生管理系统(正式版)(map数组的应用)(string应用)(引用)(文件储存的应用)(C++教学)(C++项目)
c语言·开发语言·数据结构·c++
源代码•宸2 小时前
C++高频知识点(二)
开发语言·c++·经验分享
百锦再3 小时前
.Net配置文件appsetting.json的几种读取方法
chrome·json·.net·依赖注入·appsetting·web.config
jyan_敬言3 小时前
【C++】string类(二)相关接口介绍及其使用
android·开发语言·c++·青少年编程·visual studio
liulilittle4 小时前
SNIProxy 轻量级匿名CDN代理架构与实现
开发语言·网络·c++·网关·架构·cdn·通信
tan77º4 小时前
【Linux网络编程】Socket - UDP
linux·服务器·网络·c++·udp
GiraKoo5 小时前
【GiraKoo】C++14的新特性
c++
悠悠小茉莉5 小时前
Win11 安装 Visual Studio(保姆教程 - 更新至2025.07)
c++·ide·vscode·python·visualstudio·visual studio