クラスで削除演算子をオーバーライドしたい。これが私がやろうとしていることですが、成功していません。
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;
}
あなたの宣言は正しいです。問題は、 your を実装するコードにあります。globalを呼び出す代わりにoperator delete
キーワードを使用します。次のように書きます。delete
operator delete
void Complex::operator delete(void *ptr) {
::operator delete(ptr);
}
operator new
これは、 globalを使用したことを前提としていますoperator new
。
delete による削除は非常に奇妙ですが、a の削除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*
ます。