首页 > 焦点 > C++中要求(或禁止)对象产生于heap中
C++中要求(或禁止)对象产生于heap中
网上收集 2007/11/27 9:11:01 (507)
  要求对象产生于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(){}
};

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

阅读(507) (责任编辑:城市网)
关于我们 - 联系我们 - 网站荣誉 - 广告服务 - 版权声明 - 网站地图
Copyright© 2007-2018 bj1.com.cn 首都热线 版权所有 QQ:165687462
中国·北京 粤ICP备14047004号-20