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

Char buf[sizeof(int)] = {1, 2, 0}; int* ptr = new (buf)

int;
int i = *ptr;
Тут есть UB?

23 ответов

30 просмотров

Может не скомпилироваться, если размер int будет меньше 4.

d7d1cd- Автор вопроса

Это все понятно. Вопрос про UB

Да, переиспользование хранилища без launder.

d7d1cd
Это все понятно. Вопрос про UB

https://stackoverflow.com/questions/41624685/is-placement-new-legally-required-for-putting-an-int-into-a-char-array https://stackoverflow.com/questions/4583125/char-array-as-storage-for-placement-new

Дмитрий 🎮
https://stackoverflow.com/questions/41624685/is-pl...

Оберните код в теги: 3 символа ` до и после кода (в случае одиночной конструкции достаточно 1 ` с обеих сторон). Спасибо!

d7d1cd- Автор вопроса
Aleksander Spichak
Да, переиспользование хранилища без launder.

alignas(int) unsigned char buf[sizeof(int)] = {1, 2, 0}; int* ptr = new (std::launder(buf)) int; int i = *ptr; А так правильно?

d7d1cd
alignas(int) unsigned char buf[sizeof(int)] = {1, ...

прачечная тут не нужна

d7d1cd- Автор вопроса
Vlad
прачечная тут не нужна

Выше сказали, что нужна...

Нет

Vlad
зачем тут launder?

Вроде как char/unsigned char можно только "смотреть" в репрезентацию всяких тривиальны (ранее, pod) типов. А вот для переиспользования стоража надо отмывать

Хотя.. значение ж не задано

d7d1cd
alignas(int) unsigned char buf[sizeof(int)] = {1, ...

если инту нужно 4 байта, вас ничего не спасет http://eel.is/c++draft/basic.life#1.1

Aleksander Spichak
Вроде как char/unsigned char можно только "смотрет...

прачечная нужна для отмывания других указателей на хранилище после его переиспрользования другим объектом, когда критерии transparently replaceable не выполняются

d7d1cd- Автор вопроса

в этом примере других указателей попросту нет

Да: у создаваемого int-объекта indeterminate-value, которое Вы вычисляете при инициализации i. Значения, находящиеся в buf до создания этого int-объекта, роли не играют. Кроме того, Вы не истребовали выравнивание (тоже потенциальная неопределенность). И наконец, только массивы std::byte и unsigned char способны предоставлять хранилище (обычный char никогда не является ни одним из). В данном конкретном случае у этого не будет последствий, но в более общем они могли бы быть.

d7d1cd
alignas(int) unsigned char buf[sizeof(int)] = {1, ...

std::launder() тут не требуется, к слову.

Стикер

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

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

читать файл максимально быстро? странный вопрос))
zamtmn
52
всем привет! углубившись в плюсы и начав изучать реверсинг понял, что без асм'а никуда со своими высокоабстрактными представлениями начал изучать механизмы асма, и не совсем п...
9
Привет. Сразу скажу, что на C/C++/Rust я не пишу, но тем не менее возникла потребность дебага C/C++/Rust кода. Суть: есть серверное приложение, которое периодически ведёт себ...
ninekeem 🐳
4
буквально один оставшийся вопрос при выполнении строчки mov eax, 5 операнд "5" будет присутствовать где-либо в памяти (любой), кроме как в памяти блока .code? подвопрос: как...
12
Всем ку. Подскажите, если задекларировал массив так: int arr[10] = {1, 2, 3, 4}, то в arr[4] будет мусор или нуль?
Sasha K
14
я не понимаю mov [r11+8],rcx и прочие. мы записываем значение из rcx, куда?
Bor
15
а зачем этот вопрос для удаления из чата?
Mёdkinson Medvezhkin
63
у меня такой вопрос про память в x86 возник, может кто пояснить?.. у процессора есть (как минимум) 3 типа адресов (названия "п1", "п2", "п3" --- мои, чтобы проще было дальше)...
Toideng
5
А какие расширения активно используются в промышленности? Именно идейные, по типу гадт, а не всякие оверлоадедстрингс
Степан
11
у процессора есть (как минимум) 3 типа адресов (названия "п1", "п2", "п3" --- мои, чтобы проще было дальше): - "п1" --- виртуальный адрес, то есть тот, который ресолвится в "п...
Toideng
3
Карта сайта