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指向数组时的情况 ,模板特化一下就可以了。
时间: 2024-12-10 20:24:01