在博文https://blog.csdn.net/qq_27717921/article/details/82940519已经介绍了unique_ptr和shared_ptr的使用,但是这两类的智能指针是如何做到管理指针的呢?
shared_ptr
头文件
template <typename T>
class SharedPointer {
public:
SharedPointer(T *ptr = nullptr, const std::function<void(T*)> &del = Deleter()):
p(ptr), use_c(new std::size_t(ptr != nullptr)), deleter(del) { }
SharedPointer(const SharedPointer &);
SharedPointer(SharedPointer &&) noexcept;
SharedPointer& operator=(SharedPointer);
~SharedPointer() { release(); }
std::size_t use_count() { return *use_c; }
bool unique() const { return *use_c == 1; }
operator bool() const { return p != nullptr; }
void reset(T* ptr = nullptr, const std::function<void(T*)> &del = Deleter());
void swap(SharedPointer<T>&);
T* get() const { return p; }
T& operator*() const { return *p; }
T* operator->() const { return p; }
private:
std::size_t *use_c;
T *p;
std::function<void(T*)> deleter;
void release();
};
1. 构造函数
shared_ptr<int> p1(new int (2));
SharedPointer(T *ptr = nullptr, const std::function<void(T*)> &del = Deleter()):
p(ptr), use_c(new std::size_t(ptr != nullptr)), deleter(del) { }
涉及到的Deleter放在最后来讲。
采用new返回的指针初始化shared_ptr,调用构造函数,在堆上开辟一块存储空间,存放指向这块空间指针的数量,这块空间的地址初始化use_c. new int(2)返回的指针用于初始化p.