1. shared_ptr的实现 2. weak_ptr的实现 3. enable_shared_from_this的实现 这个版本的智能指针是我去看了本机上GNU C++标准库中shared_ptr源码后写的,在我的ubuntu22.04上,源码位置在/usr/include/c++/12/bits/shared_ptr_base.h和/usr/include/c++/12/bits/shared_ptr.h下。GNU源码的可读性并不那么好...
是为了配合 shared_ptr 而引入的一种智能指针,它指向由 shared_ptr 管理的对象,但不影响对象的生命周期。通过 weak_ptr,我们可以解决 shared_ptr 的循环引用问题,避免内存泄漏。 通过shared_ptr 来创建,但不增加引用计数。当需要访问 weak_ptr 指向的对象时,可以通过 lock() 方法转换为 shared_ptr,如果转换成功,...
实现了一个简易的智能指针,并使用简单例子测试后,也没发现内存泄漏。 #include<iostream>#include<atomic>#define _CRTDBG_MAP_ALLOC#include<stdlib.h>#include<crtdbg.h>template<typenameT>classWeakPtr;template<typenameT>classSharedPtr;template<typenameT>classSharedPtr{public:friendclassWeakPtr<T>;friendvoid...
// 用weak_ptr和shared_ptr进行拷贝构造weak_ptr // 因为weak_ptr可以通过weak_ptr和shared_ptr进行拷贝构造,所以这里形参用My_Ptr_base,可以接收weak_ptr和shared_ptr实参 void_Weak_Copy_construct_from(constMy_Ptr_base<T>&left) { if(this==&left) { return; } // weak_ptr只关心引用计数器是否存活...
std::vector<std::weak_ptr<Observer>> observers_;};```3. 定义观察者类 定义一个观察者类,实...
和shared_ptr、unique_ptr 类型指针一样,weak_ptr 智能指针也是以模板类的方式实现的。weak_ptr<T>( T 为指针所指数据的类型)定义在<memory>头文件,并位于 std 命名空间中。因此,要想使用 weak_ptr 类型指针,程序中应首先包含<memory>头文件。 需要注意的是,C++11标准虽然将 weak_ptr 定位为智能指针的一种...
很多人对std::weak_ptr的认识只是不增加std::shared_ptr的引用计数,可以用来解决std::shared_ptr可能造成的循环引用问题。但是,实际对它的认识还是不够深刻,本文将从几个实际应用场景讲解,深入了解这种智能指针。比如,你是否知道可以通过std::weak_ptr来实现缓存, 还可以用来实现单例模式?
在理解weak_ptr的实现原理之前,我们首先来回顾一下shared_ptr的工作原理。 shared_ptr是一种引用计数智能指针,它通过记录有多少个shared_ptr指向同一个对象来判断该对象是否可以被释放。每当一个shared_ptr被创建时,引用计数加1;当一个shared_ptr被销毁时,引用计数减1。当引用计数为0时,表示没有任何shared_ptr...
和shared_ptr、unique_ptr 类型指针一样,weak_ptr 智能指针也是以模板类的方式实现的。weak_ptr<T>( T 为指针所指数据的类型)定义在<memory>头文件,并位于 std 命名空间中。因此,要想使用 weak_ptr 类型指针,程序中应首先包含<memory>头文件。 需要注意的是,C++11标准虽然将 weak_ptr 定位为智能指针的一种...
weak_ptr这个指针天生一副“小弟”的模样,也是在C++11的时候引入的标准库,它的出现完全是为了弥补它老大shared_ptr天生有缺陷的问题,其实相比于上一代的智能指针auto_ptr来说,新进老大shared_ptr可以说近乎完美,但是通过引用计数实现的它,虽然解决了指针独占的问题,但也引来了引用成环的问题,这种问题靠它自己是没办...