今天在工作时,看到了奇葩的结构体初始化方式,于是我查了一下C99标准文档和gcc的说明文档,终于搞清楚是怎么回事了。
假设有如下结构体定义:
typedef struct { int a, b, c; } MyStruct;
那么结构体的初始化方式如下有三种:
(1) C89的初始化方式
MyStruct test = {1, 2, 3};
这种初始化的优点是语法简单,无需输入变量名;缺点是成员变量的初始化顺序必须与声明的一致,无法乱序初始化。
(2) C99新增的初始化方式
MyStruct test = {.b = 2, .a = 1, .c = 3};
这种初始化的优点是可以乱序初始化;缺点是语法略微复杂,要打变量名。
(3) gcc的初始化方式(GNU扩展,非标准)
MyStruct test = {a : 1, b : 2, c : 3};
与上一种相同,优点可乱序初始化;缺点语法略微复杂。另外还有一个缺点——非标准,可移植性差。