Я уверен, что этот код должен быть недопустимым, поскольку он явно не будет работать, но, похоже, он разрешен для C ++ 0x FCD.
class X { /* ... */};
void* raw = malloc(sizeof (X));
X* p = new (raw) X(); // according to the standard, the RHS is a placement-new expression
::operator delete(p); // definitely wrong, per litb's answer
delete p; // legal? I hope not
Возможно, один изВы, юристы, изучающие язык, можете объяснить, как это запрещает стандарт.
Существует также форма массива:
class X { /* ... */};
void* raw = malloc(sizeof (X));
X* p = new (raw) X[1]; // according to the standard, the RHS is a placement-new expression
::operator delete[](p); // definitely wrong, per litb's answer
delete [] p; // legal? I hope not
Это ближайший вопрос Мне удалось найти.
РЕДАКТИРОВАТЬ: Я просто не покупаю аргумент, что язык стандарта, ограничивающий аргументы для функции void ::operator delete(void*)
, применим любым значимым образом к операнду delete
в delete-expression .В лучшем случае соединение между ними является чрезвычайно ненадежным, и ряд выражений допускается в качестве операндов для delete
, которые недопустимы для передачи в void ::operator delete(void*)
.Например:
struct A
{
virtual ~A() {}
};
struct B1 : virtual A {};
struct B2 : virtual A {};
struct B3 : virtual A {};
struct D : virtual B1, virtual B2, virtual B3 {};
struct E : virtual B3, virtual D {};
int main( void )
{
B3* p = new E();
void* raw = malloc(sizeof (D));
B3* p2 = new (raw) D();
::operator delete(p); // definitely UB
delete p; // definitely legal
::operator delete(p2); // definitely UB
delete p2; // ???
return 0;
}
Я надеюсь, что это показывает, что то, может ли указатель быть передан в void operator delete(void*)
, не имеет никакого отношения к тому, может ли этот же указатель использоваться в качестве операнда delete
.