больше, чем истинный размер. Причем этот overhead не определен.
new T[5]; // calls operator new[](sizeof(T)*5 + overhead)
На что идёт этот overhead? Вот тут есть хороший пример: https://stackoverflow.com/questions/4011577/placement-new-array-alignment
Он ни на что не идет, это особенность выделения памяти ОС - она не будет искать конкретно запрошенные n байт, а, чтоб быстрее, выделит первый более менее подходящий кусок. Память фрагментируется же
А почему тогда для new T такого нет? Там честный sizeof(T). T может быть довольно большим и сложным. С точки зрения запроса выделения фрагмента памяти все аналогично.
Например, на сохранение числа выделенных элементов
Я об этом первым делом думал, но нет. Тогда была бы явная формула для расчета, а не говорилось бы, что не определено. Кроме того, в примере на SO есть случаи, где overhead равен нулю.
Не путайте, пожалуйста, ОС и libc. OC выделяет память страницами, и там свои заморочки с адресацией, правами доступа, расшариванием между процессами, CoW и swap.
Зачем в стандарте описывать строго оверхед на имплементацию?
Мне больше интересует, зачем он нужен в имплементации. Что туда пишется или он используется для чего-то другого?
Ну тут надо открывать доки конкретной имплементации и смотреть
Это да. Осталось бы найти их у Texas Instruments ;)
Очень похоже, что этот оверхед только у MSVC. В Clang и GCC он отсутствует. ABI Itanium он тоже нафиг не сдался. https://stackoverflow.com/questions/51356882/overhead-of-placement-new Ну и вот такое обсуждение в комитете аж с 2004 года: https://wg21.cmeerw.net/cwg/issue476
Не стоит путать placement new и обычный new. Откуда во втором случае компилятор узнает количество элементов во время вызова delete[]?
Согласен, что необходимо где-то хранить их количество. Только тогда для placement new нужно было изменить поведение, поскольку за освобождение памяти отвечает уже разработчик. Сейчас placement new для массивов, получается, неприменим. А хотелось бы. Ну и там всё-таки не количество хранится, иначе об этом говорилось бы.
Обсуждают сегодня