c++ autoptr 的初步实现

 1 template <typename T>
 2 class AutoPtr{
 3 public:
 4     explicit AutoPtr(T* ptr)//拒绝隐式转换
 5         :ptr(ptr){}
 6     AutoPtr(AutoPtr<T>& that)
 7         :ptr(that.release()){}
 8     AutoPtr& operator=(AutoPtr<T>& that){
 9         if(&that != this)//证同
10             ptr = that.release();//并不需要在 证同测试,因为 AutoPtr的两个构造函数决定了 他们不可能会相等。
11         return *this;
12     }
13     ~AutoPtr(){
14         if(ptr){
15             delete ptr;
16             ptr = NULL;
17         }
18     }
19     T& operator* (){
20         return *this->ptr;
21     }
22     T* operator->(){
23         return &**this;
24     }
25 private:
26     T* release(){
27         T* p = ptr;
28         ptr = NULL;
29         return p;
30     }
31     T* ptr;
32 };

1,把指针封装到类模版中,用析构函数实现 delete动态分配的内存。
2,重载 '*','->' 两个运算符,使这个“智能指针对象”用起来更像一个真正的指针。
3,考虑到,当两个只能指针同时指向同一处内存时,double delete.  要“证同测试”

4,AutoPtr指向数组时的情况 ,模板特化一下就可以了。

你可能感兴趣的:(auto)