Какова правильная форма типа, которая должна использоваться для операций бинарных данных, не связанных с типзафу, включающими указатели, которые приводят к переосмыслению данных как другой тип? < /p>
Например, если бы я прочитал некоторые данные из сетевого сокета, используя recv в буфер, я мог бы тогда захотеть «переосмыслить» эти данные как какой-то конкретный тип. Данные изначально читаются с использованием void* type.
Например, для типа uint64_t у нас может быть что -то вроде:
std::vector buffer;
// call `recv`
const auto p_length = &(buffer[some_offset]);
const auto p_length_as_uint64_t = static_cast(p_length);
const uint64_t length = *p_length_as_uint64_t;
< /code>
Этот код не компилируется. Сообщение об ошибке < /p>
Error: Invalid type conversion
и относится к использованию static_cast .
Прошло некоторое время, так как я регулярно делал C ++. Я достиг к static_cast < /code> по умолчанию и был удивлен, что это не сработало. < /P>
Несколько вопросов. < /P>
Должен ли я использовать static_cast здесь? /ul>
Я подумал о том, чтобы просто изменить это на повторный интернет_кас < /code>, потому что это работает. Однако это правильная форма для использования? Я начинаю думать, что «простой» или «C-стиль»-это самая разумная вещь для использования? < /P>
const uint64_t* const p_length_as_uint64_t = (const uint64_t* const)p_length;
Подробнее здесь: https://stackoverflow.com/questions/794 ... rsions-for
Какой правильный тип актеров для использования для преобразования указателя, не являющихся типзафу для операций по перео ⇐ C++
Программы на C++. Форум разработчиков
1738868660
Anonymous
Какова правильная форма типа, которая должна использоваться для операций бинарных данных, не связанных с типзафу, включающими указатели, которые приводят к переосмыслению данных как другой тип? < /p>
Например, если бы я прочитал некоторые данные из сетевого сокета, используя recv в буфер, я мог бы тогда захотеть «переосмыслить» эти данные как какой-то конкретный тип. Данные изначально читаются с использованием void* type.
Например, для типа uint64_t у нас может быть что -то вроде:
std::vector buffer;
// call `recv`
const auto p_length = &(buffer[some_offset]);
const auto p_length_as_uint64_t = static_cast(p_length);
const uint64_t length = *p_length_as_uint64_t;
< /code>
Этот код не компилируется. Сообщение об ошибке < /p>
Error: Invalid type conversion
и относится к использованию static_cast .
Прошло некоторое время, так как я регулярно делал C ++. Я достиг к static_cast < /code> по умолчанию и был удивлен, что это не сработало. < /P>
Несколько вопросов. < /P>
Должен ли я использовать static_cast здесь? /ul>
Я подумал о том, чтобы просто изменить это на повторный интернет_кас < /code>, потому что это работает. Однако это правильная форма для использования? Я начинаю думать, что «простой» или «C-стиль»-это самая разумная вещь для использования? < /P>
const uint64_t* const p_length_as_uint64_t = (const uint64_t* const)p_length;
Подробнее здесь: [url]https://stackoverflow.com/questions/79417324/what-is-the-correct-type-of-cast-to-use-for-non-typesafe-pointer-conversions-for[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия