170 похожих чатов

В стандарте говорится, что при использовании new[] памяти может выделиться

больше, чем истинный размер. Причем этот overhead не определен.

new T[5]; // calls operator new[](sizeof(T)*5 + overhead)

На что идёт этот overhead? Вот тут есть хороший пример: https://stackoverflow.com/questions/4011577/placement-new-array-alignment

12 ответов

14 просмотров

Он ни на что не идет, это особенность выделения памяти ОС - она не будет искать конкретно запрошенные n байт, а, чтоб быстрее, выделит первый более менее подходящий кусок. Память фрагментируется же

Vyacheslav-Klimentyev Автор вопроса
Sergey Sobolev
Он ни на что не идет, это особенность выделения па...

А почему тогда для new T такого нет? Там честный sizeof(T). T может быть довольно большим и сложным. С точки зрения запроса выделения фрагмента памяти все аналогично.

Например, на сохранение числа выделенных элементов

Vyacheslav-Klimentyev Автор вопроса
Dmitriy [Отпуск]
Например, на сохранение числа выделенных элементов

Я об этом первым делом думал, но нет. Тогда была бы явная формула для расчета, а не говорилось бы, что не определено. Кроме того, в примере на SO есть случаи, где overhead равен нулю.

Sergey Sobolev
Он ни на что не идет, это особенность выделения па...

Не путайте, пожалуйста, ОС и libc. OC выделяет память страницами, и там свои заморочки с адресацией, правами доступа, расшариванием между процессами, CoW и swap.

Vyacheslav Klimentyev
Я об этом первым делом думал, но нет. Тогда была б...

Зачем в стандарте описывать строго оверхед на имплементацию?

Vyacheslav-Klimentyev Автор вопроса
Aidar Fattakhov
Зачем в стандарте описывать строго оверхед на импл...

Мне больше интересует, зачем он нужен в имплементации. Что туда пишется или он используется для чего-то другого?

Vyacheslav Klimentyev
Мне больше интересует, зачем он нужен в имплемента...

Ну тут надо открывать доки конкретной имплементации и смотреть

Vyacheslav-Klimentyev Автор вопроса
Danya🔥
Ну тут надо открывать доки конкретной имплементаци...

Это да. Осталось бы найти их у Texas Instruments ;)

Vyacheslav-Klimentyev Автор вопроса
Danya🔥
Ну тут надо открывать доки конкретной имплементаци...

Очень похоже, что этот оверхед только у MSVC. В Clang и GCC он отсутствует. ABI Itanium он тоже нафиг не сдался. https://stackoverflow.com/questions/51356882/overhead-of-placement-new Ну и вот такое обсуждение в комитете аж с 2004 года: https://wg21.cmeerw.net/cwg/issue476

Vyacheslav Klimentyev
Очень похоже, что этот оверхед только у MSVC. В Cl...

Не стоит путать placement new и обычный new. Откуда во втором случае компилятор узнает количество элементов во время вызова delete[]?

Vyacheslav-Klimentyev Автор вопроса
magras
Не стоит путать placement new и обычный new. Откуд...

Согласен, что необходимо где-то хранить их количество. Только тогда для placement new нужно было изменить поведение, поскольку за освобождение памяти отвечает уже разработчик. Сейчас placement new для массивов, получается, неприменим. А хотелось бы. Ну и там всё-таки не количество хранится, иначе об этом говорилось бы.

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Гайс, вопрос для разносторонее развитых: читаю стрим с юарта, нада выделять с него фреймы с определенной структурой, если ли чо готовое, или долбаться с ринг буффером? нада у...
Vitaly
9
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
длина пакета фиксированная, или меняется?
Okhsunrog
7
Карта сайта