C ++和C中的联合初始化
我已经在定义为的头文件中构建了一个使用常量的工作C库
typedef struct Y { union { struct bit_field bits; uint8_t raw[4]; } X; } CardInfo; static const CardInfo Y_CONSTANT = { .raw = {0, 0, 0, 0 } };
我知道.raw
初始化程序只是C语法。
如何在其中使用联合定义常量,以便我可以在C和C ++中使用它们。
我有同样的问题。 对于C89,以下情况属实:
使用C89样式的初始化程序,必须按声明的顺序初始化结构成员,并且只能初始化union的第一个成员
我在下面找到了这样的解释: 结构和联合的初始化
我相信C ++ 11允许你编写自己的构造函数,如下所示:
union Foo { X x; uint8_t raw[sizeof(X)]; Foo() : raw{} { } };
这个默认值 – 初始化Foo
类型的联合与活动成员raw
,它具有零初始化的所有元素。 (在C ++ 11之前,没有办法初始化不是完整对象的数组。)
我决定选择以下路径。
- 不要使用
.member
初始化。 - do nost使用
static const struct Foobar
初始化成员
而是声明全局变量:
extern "C" { extern const struct Foobar foobar; }
并在全局部分初始化它:
struct Foobar foobar = { 0, 0, 0, 0 };
而不是用现代的ANSI C99语法来窃听C ++编译器我让链接器完成工作是解码C符号。
C89允许通过直接列出要初始化的元素来初始化联合(就像您在代码中所拥有的那样)。 C99改变了这一点,这样你就可以通过它的第一个元素来启动联合。
C ++只允许这种forms的初始化 – 由第一个元素组成。 所以这是适用于任何一种情况的代码:
static const CardInfo Y_CONSTANT = {{0, 0, 0, 0 } };