AutoCAD 3DMAX C语言 Pro/E UG JAVA编程 PHP编程 Maya动画 Matlab应用 Android
Photoshop Word Excel flash VB编程 VC编程 Coreldraw SolidWorks A Designer Unity3D
 首页 > C++

C++中要求(或禁止)对象产生于heap中

51自学网 http://www.wanshiok.com
  要求对象产生于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(){}
};

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

 

 

 
上一篇:小心C++编译器给我们带来的麻烦  下一篇:乌托邦式的接口和实现分离技术