unique_ptr的原理及仿写

- 独占指针只允许有一份指针指向这份数据,不能将同一个裸指针赋值给多个智能指针
- 也就是在这个模板类里面,拷贝构造和拷贝赋值函数都被删除了,不允许调用,智能移动构造和移动赋值
- 独占指针不允许隐式构造
- 提供了bool运算符重载
- 释放内存使用的是deleter(删除器),里面会判断delete或者delete[]
template<class T>
class MyUnique_ptr {
private:
T* m_ptr;
public:
explicit MyUnique_ptr(T* ptr = nullptr) : m_ptr(ptr) {
ptr = nullptr;
}
MyUnique_ptr(const MyUnique_ptr& src) = delete;
MyUnique_ptr& operator=(MyUnique_ptr& src) = delete;
MyUnique_ptr(MyUnique_ptr&& src) {
m_ptr = src.m_ptr;
src.m_ptr = nullptr;
}
MyUnique_ptr& operator=(MyUnique_ptr&& src) {
if (&src == this) return *this;
m_ptr = src.m_ptr;
src.m_ptr = nullptr;
return *this;
}
~MyUnique_ptr() {
delete m_ptr;
m_ptr = nullptr;
}
T* get() {
return m_ptr;
}
T* release() {
T* ptr = m_ptr;
m_ptr = nullptr;
return ptr;
}
void reset(T* ptr = nullptr) {
delete m_ptr;
m_ptr = ptr;
ptr = nullptr;
}
void swap(MyUnique_ptr<T>& src) {
T* temp;
temp = src.m_ptr;
src.m_ptr = m_ptr;
m_ptr = temp;
}
T& operator*() const {
return *m_ptr;
}
T* operator->() const {
return (&**this);
}
operator bool() const {
return m_ptr != nullptr;
}
template<class U>
friend void swap(MyUnique_ptr<U>& a, MyUnique_ptr<U>& b);
};
template<class T>
MyUnique_ptr<T> make_MyUnique(T* ptr = nullptr) {
return MyUnique_ptr<T>(ptr);
}
template<class T>
MyUnique_ptr<T> make_MyUnique(MyUnique_ptr<T>&& src) {
return MyUnique_ptr<T>(forward<MyUnique_ptr<T>>(src));
}
template<class T>
void swap(MyUnique_ptr<T>& a, MyUnique_ptr<T>& b) {
T* temp;
temp = a.m_ptr;
a.m_ptr = b.m_ptr;
b.m_ptr = temp;
}