首页 | 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(){}
    };

      这确实是比较简单的事情。