Ответ 1
Да, вы можете перегрузить оператор new для непрямого указателя. Бросок гарантирует, что будет выполняться перегрузка указателя void.
Например
void* operator new(size_t s, env * e);
Я просматриваю код пользовательского контейнера, и некоторые его части создают такие элементы:
::new( (void*)&buffer[index] ) CStoredType( other );
а некоторые - вот так:
::new( &buffer[index] ) CStoredType( other );
Итак, оба используют новое размещение для вызова конструктора копирования для создания элемента путем копирования другого элемента, но в одном случае указатель на новое хранилище элементов передается как есть, а в другом - на void*
.
Влияет ли это на void*
?
Да, вы можете перегрузить оператор new для непрямого указателя. Бросок гарантирует, что будет выполняться перегрузка указателя void.
Например
void* operator new(size_t s, env * e);
Компилируемый пример:
#include <iostream>
#include <new>
void* operator new(std::size_t, int* x)
{
std::cout << "a side effect!" << std::endl;
return x;
}
int main()
{
int buffer[1];
new ((void*)&buffer[0]) char;
new (&buffer[0]) char;
}