6

我想覆盖我班级中的删除运算符。这是我正在尝试做的,但没有成功。

class Complex{              
    void *operator new(size_t s);
    void operator delete(void *ptr);
};

void Complex::operator delete(void *ptr){
    delete ptr;
}

我得到错误:

删除 void* 未定义

4

3 回答 3

5

如错误消息所示,您不能delete使用void*. 试试这个:

// See http://www.informit.com/guides/content.aspx?g=cplusplus&seqNum=40

#include <new> // for size_t

class Complex
{
public:
 Complex() {}
 ~Complex() {}
 static void* operator new (size_t size) {
  return new char[size];
 }
 static void operator delete (void *p) {
  return delete[] static_cast<char*>(p);
 }
};

int main () {
  Complex *p = new Complex;
  delete p;
}
于 2013-02-11T20:06:09.617 回答
4

你的声明是正确的。问题出在实现您的代码中operator delete:它使用关键字delete而不是调用全局operator delete. 像这样写:

void Complex::operator delete(void *ptr) {
    ::operator delete(ptr);
}

这是假设您operator new使用了全局operator new.

于 2013-02-11T20:12:11.833 回答
0

通过delete删除比较奇怪,但是删除avoid*就是UB。

此外,size_t它不是内置类型:它是在<cstddef>.

这可以很好:

#include <cstddef>

class Complex
{              
    void *operator new(size_t s);
    void operator delete(void *ptr);
};

void* Complex::operator new(size_t s)
{ return new char[s]; } //allocate a buffer of s bytes

void Complex::operator delete(void *ptr)
{ delete[] static_cast<char*>(ptr); } //deallocate the buffer

实际上,我们在 new / delete 中连贯地分配/取消分配适当大小的缓冲区。

new中,我们要求系统给我们我们需要的字节。我使用的char[s]sincechar是内存size_t度量单位:sizeof(char) == 1根据定义。

delete我们必须将由 标识的字节返回给系统ptr。由于我们将它们分配为char[],我们必须将它们删除为char[],因此使用 ofdelete[]和强制转换为char*

于 2013-02-11T20:07:31.677 回答