智能指针
namespace smart { // 引用计数类.
class smart_count
{
public: smart_count(int c = 0) : use_count(c) {}
~smart_count() {} // 增加引用计数, 并返回计数值.
int addref() { return ++use_count; } // 减少引用计数, 并返回计数值.
int release() { return --use_count; } private: // 计数变量.
int use_count; }; // 智能指针.
template class smart_ptr
{
public: // 构造指针, 并使引用计数置为1.
explicit smart_ptr (T* ptr) : p(ptr), u(new smart_count(1)) {} // 构造空指针.
explicit smart_ptr () : p(NULL), u(NULL) {} // 智能指针析构.
~smart_ptr (void) {
// 如果引用计数等于0, 则删除数据和引用计数, 并置p为NULL. // 此处需要注意的是, 共用的u并未置为 NULL, 在其它指针析构 // 时, p为NULL, 则不会重复delete. if (p && u->release() <= 0) { delete p; delete u; p = NULL; } } // 智能指针拷贝构造函数.
smart_ptr (const smart_ptr& t)
{
p = t.p; u = t.u;
if (u) // 必须判断空值.
{
u->addref(); // 增加引用计数.
}
} // 指针赋值.
void operator= (smart_ptr& t)
{
// 首先将引用计数减1, 然后再判断是否小于0, 如果小于0, 则delete.
if (p && u->release() <= 0) { delete p; delete u; } // 直接赋值.
p = t.p; u = t.u;
if (u) // 必须判断空值.
{
u->addref(); // 增加引用计数.
}
} // 重载->操作和*操作符.
T *operator-> (void) { return p; } T& operator *(void) { return *p; } // 重载!操作符.
bool operator! () const { return !p;} // 重载指针bool值操作符.
typedef smart_ptr this_type;
typedef T * this_type::*unspecified_bool_type; operator unspecified_bool_type() const { return !p ? 0: &this_type::p; } // 得到原指针.
T* get() { return p; } void reset(T* ptr) { // 首先将引用计数减1, 然后再判断是否小于0, 如果小于0, 则delete.
if (p && u->release() <= 0) { delete p; delete u; } // 赋值, 如果是NULL, 则不创建引用计数.
p = ptr; if (p) u = new smart_count(1); else u = NULL; } void reset(smart_ptr& t) { // 首先将引用计数减1, 然后再判断是否小于0, 如果小于0, 则delete.
if (p && u->release() <= 0) { delete p; delete u; } // 赋值. p = t.p; u = t.u; if (u) // 必须判断空值. { u->addref(); // 增加引用计数. } } private: T* p; smart_count* u; }; // 重载==操作符.
template inline bool operator==(smart_ptr & a, smart_ptr & b) { return a.get() == b.get(); } // 重载!=操作符.
template inline bool operator!=(smart_ptr & a, smart_ptr & b) { return a.get() != b.get(); } } 工厂管理 类工厂工厂,类工厂工厂管理所有的工厂,工厂管理所有的类和对象,

posted on 2016-08-12 15:42  默默淡然  阅读(317)  评论(0编辑  收藏  举报