我想覆盖我班级中的删除运算符。这是我正在尝试做的,但没有成功。
class Complex{
void *operator new(size_t s);
void operator delete(void *ptr);
};
void Complex::operator delete(void *ptr){
delete ptr;
}
我得到错误:
删除 void* 未定义
我想覆盖我班级中的删除运算符。这是我正在尝试做的,但没有成功。
class Complex{
void *operator new(size_t s);
void operator delete(void *ptr);
};
void Complex::operator delete(void *ptr){
delete ptr;
}
我得到错误:
删除 void* 未定义
如错误消息所示,您不能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;
}
你的声明是正确的。问题出在实现您的代码中operator delete:它使用关键字delete而不是调用全局operator delete. 像这样写:
void Complex::operator delete(void *ptr) {
::operator delete(ptr);
}
这是假设您operator new使用了全局operator new.
通过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*。