7
#include <new>
#include <cstdlib>
#include <iostream>
#include <stdexcept>

struct foo {};

inline void* operator new(size_t size, foo*) throw (std::bad_alloc)
{
    std::cout << "my new " << size << std::endl;
    return malloc(size);
}

inline void operator delete(void* p, foo*) throw()
{
    std::cout << "my delete" << std::endl;
    free(p);
}

int main()
{
    delete new((foo*)NULL) foo;
}

输出(通过ideone):

my new 1

我的想法是 C++ 会释放一个带有附加参数的新对象,并匹配删除相同的参数,但我显然是不正确的。

让上面的代码调用我的重载删除的正确方法是什么?

4

1 回答 1

8

当您使用任何形式的放置 new(版本除外)时std::nothrow_t,您需要显式销毁对象并以您认为合适的任何方式释放其内存。但是,仍然需要存在的重载版本operator delete(),因为如果对象的构造引发异常,则使用它!在这种情况下,不会返回指针,因为抛出了异常。因此,在这个分配过程中必须摆脱内存。

也就是说,您main()应该看起来像这样:

int main()
{
    foo* p = new (static_cast<foo*>(0)) foo;
    p->~foo();
    operator delete(p, static_cast<foo*>(0));
}
于 2012-11-21T23:52:48.450 回答