首页 | IT新闻 | 硬件 | 操作系统 | 开发 | 网络编程 | 数据库 | 热门框架 | 网络安全 | 组网 | 建站指南 | 网页制作 | 特效 | 实用技巧 | 服务器 | 办公 | QQ | 探索 | 社区

  • 技术部落
  • 部落首页 > 程序开发 > C/C#/C++ > 正文
  • C++中要求(或禁止)对象产生于heap中
      2007-2-25  来源:网络资源  编辑:Jsbulo  热度:

    要求对象产生于Heap之中

       考虑如下代码:

    classHeapClass
    {
      public:
       voidDestory() const {deletethis;}
      private:
       ~HeapClass(){}
    };
    HeapClass* ptr = newHeapClass;
    ptr->Destory();
       这样的调用真是很厉害,想生成非Heap对象都不成了。

       对于继承和组合的情况不想多说了,比较无趣的说。

    判断某个对象是否位于Heap内

       考虑如下代码:

    newHeapClass(* newHeapClass);
       你觉得编译器应该怎么做?

       1.调用operator new

       2.调用Constructor

       3.调用第二个operator new

       4.调用第二个Constructor

       但是可以让人足够惊讶,编译器对此并不做承诺,所以实际的实现可能是:

       1.调用operator new

       2.调用第二个operator new

       3.调用Constructor

       4.调用第二个Constructor

       而VC6是这样实现的。

    classHeapClass
    {
      private:
       void* operatornew[](size_tsize);
       typedefconstvoid * RawAddress;
       voidoperatordelete[](void* ptr);
      public:
       voidoperatordelete(void *ptr)
       {
        printf("delete\n");
        ::operatordelete(ptr);
        m_address.erase(std::remove(m_address.begin(),m_address.end(),ptr),m_address.end());
        return;
       }
       void* operatornew(size_tsize)
       {
        printf("new\n");
        void * ptr = ::operatornew(size);
        m_address.push_back(ptr);
        returnptr;
       }
       HeapClass()
       {
        printf("Constructor!\n");
       }
       HeapClass(constHeapClass&)
       {
        printf("copy Constructor!\n");
       }
       virtualvoidDestory() const {deletethis;}
       virtual ~HeapClass() = 0;
       boolisOnHeap() const
       {
        // const void * rawAddress = dynamic_cast<const void *>(this);
        constvoid * rawAddress = (constvoid *)(this);
        std::deque<RawAddress>::iteratoriter = std::find(m_address.begin(),m_address.end(),rawAddress);
        returniter != m_address.end();
       }
       private:
        staticstd::deque<RawAddress> m_address;
      };

      HeapClass::~HeapClass(){}
      std::deque<HeapClass::RawAddress> HeapClass::m_address;
      classDHeapClass:publicHeapClass
      {};
       我在VC6中写了这个Demo测试了一下,但是const void * rawAddress = dynamic_cast<const void *>(this);会出现异常,这让我觉得很郁闷,所以这个Demo只能支持普通的继承方式,不支持多种继承和虚拟继承。

    禁止对象产生于heap之中

       考虑如下代码:

    classHeapClass
    {
      private:
       void* operatornew(size_tsize);
       void* operatornew[](size_tsize);
       voidoperatordelete(void *ptr);
       voidoperatordelete[](void* ptr);
      public:
       HeapClass(){printf("Constructor!\n");}
       HeapClass(constHeapClass&){printf("copy Constructor!\n");}
      public:
       ~HeapClass(){}
    };
       这确实是比较简单的事情。
    相关链接