У меня есть этот пример кода, который выдает ошибку, когда я пытаюсь исправить одно из предупреждений GCC.
#include <stdint.h>
//
typedef union someStruct
{
uint64_t All;
struct
{
uint64_t Foo : 40;
uint64_t Bar : 24;
} Field;
} someStruct;
#define bits_64 ((uint64_t)(-1))
//
typedef union bits
{
uint64_t oneBit: 1;
uint64_t twoBits: 2;
uint64_t threeBits: 3;
uint64_t fourBits: 4;
uint64_t fiveBits: 5;
uint64_t sixBits: 6;
uint64_t sevenBits: 7;
uint64_t fourtyBits: 40;
uint64_t All;
} bits;
#define bits_40 (((bits)(-1)).fourtyBits)
//
int main()
{
someStruct x;
someStruct y;
x.Field.Foo = bits_64; //-Woverflow warning
//trying to fix the warning with using the bits union
y.Field.Foo = bits_40; // but this throws the error msg below
/*
<source>:30:19: error: cast to union type from type not present in union
30 | #define bits_40 (((bits)(-1)).fourtyBits)
| ^
*/
return 0;
}
Как я могу использовать объединение, чтобы определить любое количество битов и назначить его любому полю структуры?
P.S. Я не могу использовать перечисления и/или определить переменную объединения; Я должен использовать макросы таким образом, чтобы соответствовать кодовой базе.
Возможно, составной литерал: (bits)(-1)
--> (bits){.All = -1}
?
#define BITS(N) ((1ULL<<(N) - 1)
Ваш #define
для bits_40
должен выглядеть так:
#define bits_40 (((bits){.All = -1)).fourtyBits)
Вы также можете просто сделать:
#define bits_40 ((1ULL << 40) - 1)
и полностью пропустите структуру bits
. Или вы можете определить макрос BIT_MASK
следующим образом:
#define BIT_MASK(bits) ((1uLL << bits) - 1)
:
:
x.Field.Foo = BIT_MASK(40);
ошибка компилятора жалуется на макрос. он думает, что я пытаюсь использовать объединение как функцию или что-то в этом роде