我想在我的班级中覆盖删除操作符。这是我想要做的,但没有成功。
class Complex{
void *operator new(size_t s);
void operator delete(void *ptr);
};
void Complex::operator delete(void *ptr){
delete ptr;
}
我收到错误:
删除void *未定义
答案 0 :(得分:4)
如错误消息所示,您无法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;
}
答案 1 :(得分:2)
您的声明是正确的。问题在于实现operator delete
的代码:它使用关键字delete
而不是调用全局operator delete
。写得像这样:
void Complex::operator delete(void *ptr) {
::operator delete(ptr);
}
假设您的operator new
使用全局operator new
。
答案 2 :(得分:0)
通过删除删除很奇怪,但删除void*
是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]
,因为根据定义char
是内存size_t
度量的单位:sizeof(char) == 1
。
在delete
中,我们必须向系统返回ptr
标识的字节。
由于我们将其分配为char[]
,因此我们必须将其删除为char[]
,因此使用delete[]
并将广告投放到char*
。