Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск  
 
 
Рейтинг 4.81/21: Рейтинг темы: голосов - 21, средняя оценка - 4.81
 Аватар для dopleref
42 / 52 / 33
Регистрация: 15.12.2015
Сообщений: 199

Приведение структуры к uint32_t

24.08.2017, 14:49. Показов 4772. Ответов 22
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день!
Есть переменная пользовательского типа, представляющая собой
структуру размером 32 байта, хочу получить ее значение в переменной типа uint32_t,
как это лучше сделать?

Структура
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
typedef struct
{
#if __BYTE_ORDER == __LITTLE_ENDIAN
    uint32_t interface  : 3;
    uint32_t number     : 8;
    uint32_t command    : 9;
    uint32_t type       : 9;
    uint32_t nodata     : 3;
#elif __BYTE_ORDER == __BIG_ENDIAN
    uint32_t nodata     : 3;
    uint32_t type       : 9;
    uint32_t command    : 9;
    uint32_t number     : 8;
    uint32_t interface  : 3;
#else
#error "__BYTE_ORDER not defined"
#endif
}
abtci_protocol_header;
Хочу сделать что то типа такого (пример понятное дело не работает):
C++
1
2
abtci_protocol_header header;
uint32_t id = (uint32_t) header;
1
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
24.08.2017, 14:49
Ответы с готовыми решениями:

Как побитово скопировать uint32_t в float, минуя при этом выделения uint32_t в оперативную память
Всем привет, недавно заинтересовал такой вопрос ниже. Как ПОБИТОВО скопировать uint32_t в float, минуя при этом выделения uint32_t в...

Преобразовать uint8t* to uint32_t
Всем привет туплю и никак не могу правильно решить задачу на вход подается буфер формата 1 - 0x00 0x00 0x00 0x01 0x00 0x00 0x00...

uint32_t this decimal constant is unsigned only in ISO C90
Пишу так: uint32_t i=2147483648; Компилятор выдает: this decimal constant is unsigned only in ISO C90 И работает как со знаковой...

22
19501 / 10106 / 2461
Регистрация: 30.01.2014
Сообщений: 17,825
30.08.2017, 15:10
Студворк — интернет-сервис помощи студентам
Цитата Сообщение от УГнетатель Посмотреть сообщение
Guarantee даётся для структур в union-е. А int — не структура.
Вот именно...

Вот видите, об этом я и говорил:
Цитата Сообщение от DrOffset Посмотреть сообщение
И если ты сходу не сможешь вспомнить все ограничения и оговорки, которые накладывают вышеупомянутые "хакерские" способы, то и не стоит их применять.
Ну и, кому интересно увидеть упоминание UB в этом контексте прямым текстом, могут почитать параграф 6.8 про доступ к объекту после завершение его времени жизни. А активация другого члена union однозначно приводит к завершению времени жизни предыдущего, как описано в 12.3/5.

Добавлено через 39 минут
Цитата Сообщение от УГнетатель Посмотреть сообщение
Можно ли относиться к типу T как к структуре с единственным полем типа T, по аналогии с тем, как стандарт в некоторых аспектах позволяет относиться к переменным не-массивам как к массивам с одним элементом?
Я думаю, нельзя. Но код, который он выше привел с одинаковыми членами union, все равно, на мой взгляд, легален. В том же 6.8 этот момент раскрывается:

If, after the lifetime of an object has ended and before the storage which the object occupied is reused or
released, a new object is created at the storage location which the original object occupied, a pointer that
pointed to the original object, a reference that referred to the original object, or the name of the original
object
will automatically refer to the new object and, once the lifetime of the new object has started, can be
used to manipulate the new object
, if
(8.1) — the storage for the new object exactly overlays the storage location which the original object occupied,
(8.2) — the new object is of the same type as the original object (ignoring the top-level cv-qualifiers), and
(8.3) — the type of the original object is not const-qualified, and, if a class type, does not contain any non-static
data member whose type is const-qualified or a reference type, and
(8.4) — the original object was a most derived object (4.5) of type T and the new object is a most derived
object of type T (that is, they are not base class subobjects).
0
1130 / 789 / 232
Регистрация: 12.04.2010
Сообщений: 2,012
30.08.2017, 15:28
Цитата Сообщение от УГнетатель Посмотреть сообщение
А как можно читать из поля, которое не хранится?
УГнетатель, в любой момент времени в памяти хранится какая-то последовательность значений. Не может "ничего не храниться".

Что значит
C++
1
2
3
4
5
6
7
union U{
  int a;
  char c[ sizeof(int) ];
} u;
// ...
int n; 
n = u.a;
Это значит скопировать 4 байта из адреса переменной u по адресу переменной n. Вот что я вижу в окне дизассемблера.
Assembler
1
2
3
n = u.a;
011D16F3 8B 45 F8 mov eax,dword ptr [u] 
011D16F6 89 45 EC mov dword ptr [n],eax
По адресу ptr [u] не может "ничего не храниться". Там хранится некоторая последовательность бит.
Например, после операций
C++
1
2
3
4
5
u.c[0] = 0;
u.c[1] = 0x11;
u.c[2] = 0x22;
u.c[3] = 0x33;
int n = u.a;
по адресу &u будут записаны 00 11 22 33. И значение переменной n станет равным 0x33221100.
0
17 / 16 / 3
Регистрация: 18.08.2017
Сообщений: 54
31.08.2017, 03:29
Цитата Сообщение от Alex5 Посмотреть сообщение
в любой момент времени в памяти хранится какая-то последовательность значений.
Такое общее утверждение без дополнительных уточнений может быть спорным.


А массив char-ов, unsigned char-ов или std::byte с размером и выравниванием как у объекта называется представлением этого объекта.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
31.08.2017, 03:29

Помещение структуры в вектор, удаление структуры, изменение элементов структуры
Здравствуйте. Помогите разобраться с тем, как: 1 - находить элементы в векторе зная уникальный элемент структуры. 2 - удалять...

Приведение структуры матрицы к ленточной
Добрый вечер, извините за наглость, но не мог бы кто-нибудь помочь? естественно не за просто так. Задали курсовик делать, а мозгов не...

Рефлексия: как происходит приведение из object в производные классы и структуры
Объясните пожалуйста, даю кусок кода из книги Шилдта + 1-2 метода дописанных самостоятельно: using System; using System.Reflection;...

SysTick_GetPeriod(uint32_t frequency)
Как правильно? uint32_t SysTick_GetPeriod(uint32_t frequency) { return (system_GetCoreClock() / frequency); } или ...

C + IAR + uint32_t to char
Не уверен что в нужную тему вопрос, по истине детский. #ymstude <stdint.h> #ymstude <stdlib.h> ... uint32_t FREQ_SIT =...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
23
Ответ Создать тему
Новые блоги и статьи
сукцессия 14. Обновленная схема модели
anaschu 28.06.2026
ГЛОБАЛЬНАЯ ОПИСАТЕЛЬНАЯ СПЕЦИФИКАЦИЯ ЭКОСИСТЕМНОЙ МОДЕЛИ «SOIL CHEMISTRY & MYCORRHIZA 2. 0» https:/ / ibb. co/ NnkGpfMd Представленная интегрированная схема описывает непрерывную нелинейную. . .
сукцессия 13. Питон модель трехзонного мицелия, пока что в основном арбускулярного
anaschu 28.06.2026
## Разработка агентной модели микоризной сукцессии: от выявления артефактов к созданию комплексной системы ### Аннотация Представлено исследование по разработке агентной модели микоризной. . .
сукцессия 12. краткий список проверок модели перед запуском.
anaschu 27.06.2026
Скрытые отказы в моделях систем динамики (SD-models) экологических систем: два случая из практики Контекст Разбирался прототип модели систем динамики (SD-модели) микоризной сукцессии: пять. . .
Сукцессия 11. Проверка орудий перед войной: разработка через тестирование
anaschu 27.06.2026
Как не дать модели соврать самой себе: проверки для симуляции микоризной сукцессии Введение Когда вы строите математическую модель живой системы — грибов, растений, почвы — главная опасность. . .
10 сукцессия. Питон код войны грибов и растений
anaschu 27.06.2026
import numpy as np class PlantAgent: def __init__(self, name, strategy, initial_biomass): self. name = name self. strategy = strategy # "greedy" (широколиственные) или. . .
сукцессия 9. Математика подлости: как растения предали грибных друзей
anaschu 27.06.2026
Статья 2. Глобальная фосфорная война: эволюционно-экономические механизмы распределения биомов Земли Введение: Экологический рынок как игра с нулевой суммой Традиционная экология долгое время. . .
сукцессия 8. Как я спорил с ИИ, которые - агенты растений и ненавистники грибов!
anaschu 27.06.2026
Статья 1. Хроники грибного восстания: как Сократов диалог разрушил академические догмы ИИ Введение: Синдром «цифрового учебника» Современные большие языковые модели (LLM) обладают колоссальным. . .
Главный вопрос моделирования сукцессии
anaschu 27.06.2026
главный вопрос. Если эктомикориза лучше добывает недоступный фосфор. И ее масса максимальна из всех. А широколиственный лес тоже имеет самую крутую биомассу. То почему не возникло их симбиоза? Это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru