//////////////////////////////////////
 ///类析构以后,成员变量内存空间释放,
 ///函数 和 变量 还是可以引用的
 //////////////////////////////////////
 #include <iostream>
 using namespace std;

 class CTest
 {
 public:
     CTest();
     ~CTest();
     void Print() { cout<<"....."<<m_refCount<<endl; }
     void AddRef();
     void ReleaseRef();
     int GetRef() { return m_refCount; }
     void destroy();
     ); return m_ptr;}
     int* getPtr(){ return m_ptr; }
     void setPtr2(int* p2) { m_ptr2 = p2;}

 private:
     int        m_refCount;
     int*    m_ptr;
     int*    m_ptr2;
 };

 CTest::CTest()
 {
     m_refCount = ;
     m_ptr = NULL;
 }
 CTest::~CTest()
 {
     m_refCount = ;
     delete m_ptr;//new的内存需要delete释放, 不然内存泄露。 系统只给指针值清空
 }

 void CTest::AddRef()
 {
     ++m_refCount;
     Print();
 }

 void CTest::ReleaseRef()
 {
     --m_refCount;
     Print();
     )
     {
         delete this;
         //return;
         Print();
     }
 }

 void CTest::destroy()
 {
     delete this;
 }

 int main()
 {
     CTest* ct = new CTest;    //一定要声明为指针,不然delete时会报错。
     /*for(int _i = 0; _i < 5; ++_i)
     {
         ct->AddRef();
     }

     for(int _i = 0; _i < 6; ++_i)
     {
         ct->ReleaseRef();
     }*/
     int *a = NULL;
     a = ct->setPtr();
     cout<<"&a1 = "<<a<<endl;
     cout<<"a1 = "<<(*a)<<endl;

     );
     ct->setPtr2(b);
     delete ct;
     cout<<"m_ptr = "<<(ct->getPtr())<<endl;
     cout<<"&a1 = "<<a<<endl;
     cout<<"a1 = "<<(*a)<<endl;

     cout<<"b = "<<*b<<endl;
     ct->Print();
     //ct->ReleaseRef();
     ct->Print();

     system("pause");
     ;
 }

C++提前delete的更多相关文章

  1. 浅谈 C++ 中的 new/delete 和 new[]/delete[]

    在 C++ 中,你也许经常使用 new 和 delete 来动态申请和释放内存,但你可曾想过以下问题呢? new 和 delete 是函数吗? new [] 和 delete [] 又是什么?什么时候 ...

  2. 声明提前js变量

    声明提前问题相关 js的变量声明语句无论出现在何处,都会先与其他代码首先被执行,使用var声明关键词声明变量的 作用于是当前的执行上下文,有可能是外围函数,或者,当变量声明在函数体之外时,则为全局变量 ...

  3. C++11 之 delete 和 default

    1  特殊成员函数 设计一个类,没有成员函数 (member function),只有数据成员 (member data) class DataOnly { private: std::string ...

  4. 深入理解JS的delete

    原文链接: Understanding delete原文作者: Kangax原文日期: 2010年01月10日 翻译日期: 2014年02月07日 翻译人员: 铁锚 !!!!!!!!草稿版本的翻译完成 ...

  5. 【转】浅谈 C++ 中的 new/delete 和 new[]/delete[]

    在 C++ 中,你也许经常使用 new 和 delete 来动态申请和释放内存,但你可曾想过以下问题呢? new 和 delete 是函数吗? new [] 和 delete [] 又是什么?什么时候 ...

  6. 浅谈c++ new and delete or new [] and delete []

    http://www.cnblogs.com/hazir/p/new_and_delete.html 在 C++ 中,你也许经常使用 new 和 delete 来动态申请和释放内存,但你可曾想过以下问 ...

  7. C++11 之 &quot; = delete &quot;

    1  缺省函数 设计一个类,没有成员函数 (member function),只有成员数据 (member data) class DataOnly { private: std::string st ...

  8. C++11 之 " = delete "

    1  缺省函数 设计一个类,没有成员函数 (member function),只有成员数据 (member data) class DataOnly { private: std::string st ...

  9. 【M8】了解各种不同意义的new和delete

    1.首先考虑new operator,new operator 可以认为做了三件事情:a.调用operator new分配一块内存:b.在这块内存上调用构造方法构造对象:返回指针. 2.operato ...

随机推荐

  1. 【HDU4612】 双连通分量求桥

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4612 题目大意:给你一个无向图,问你加一条边后最少还剩下多少多少割边. 解题思路:好水的一道模板题.先 ...

  2. js去除中间空格

    / 功能: 1)去除字符串前后所有空格 // 2)去除字符串中所有空格(包括中间空格,需要设置第2个参数为:g) function Trim(str,is_global) { var result;  ...

  3. 面向系统管理员的10款Linux GUI工具 (转自51cto)

    如果你是名系统管理员,现已到了Linux非知道不可的地步.如果你在更庞大的环境下工作,更是如此.许多企业组织已迁离了一切都借助点击式GUI来管理的Windows.幸好,Linux也有许多GUI工具可以 ...

  4. Cookie 知识点再整理

    1. Cookie  是存储在客户端 内存 或者 硬盘(例如火狐把 Cookie 存储在 C:\Documents and Settings\用户名\Application Data\Mozilla\ ...

  5. 有return语句情况下,try-catch-finally的执行顺序

    重要结论: 1.不管有没有出现异常,finally块中代码都会执行 2.当try和catch中有return时,finally仍然会执行 3.finally是在return后面的表达式运算后执行的(此 ...

  6. mysql中profile的使用

    1.profile在mysql5.0.37及其以上版本中可用 2.查看profile是否可用SELECT @@profiling;来查看是否已经启用profile,如果profilng值为0,可以通过 ...

  7. css页面布局基础

    1.盒模型属性包括boder.margin.padding.width.height,这些属性可以使用快捷方式表示,顺序为上右下左,值之间用空格隔开. 2.使用clip和overflow属性时,pos ...

  8. Hadoop离线项目介绍(不包括程序)

    一:项目场景 1.需求分析 根据用户行为数据进行程序的处理,得到结果保存到关系型数据库中 需要收集用户(系统使用者)在不同客户端上产生的用户行为数据,最终保存到hdfs上 需要明确收集字段的相关信息, ...

  9. ERROR 2006 (HY000) at line xx: MySQL server has gone away 解决方法

  10. SQL基础巩固1

    直接开门见山------F4 1.查询 对指定的数据表或是视图进行检索查询,找出符合查询条件功能,具体包括以下SQL语法如下所示,其中[]为可选项 Select<列名> From<表 ...