• 类对象管理方式


    智能指针
    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(); } } 工厂管理 类工厂工厂,类工厂工厂管理所有的工厂,工厂管理所有的类和对象,

  • 相关阅读:
    有关数据恢复的几个概念的理解
    cmsr 1.0.6
    Cmsr 1.0.5
    Cmsr 1.0.4
    vue中的v-model 与 .sync
    es6中clss做了些什么 怎么继承
    Cmsr 1.0.2
    Cmsr 1.0.1
    Cmsr 1.0.0
    VUE3.0新特性
  • 原文地址:https://www.cnblogs.com/liangxiaofeng/p/5765220.html
Copyright © 2020-2023  润新知