在没有赋值的情况下初始化struct?

我无法在互联网上找到答案,所以这是我的问题:我可以定义一个结构实例而不将其分配给C中的本地或全局变量吗? 例如:

struct A { int b; } struct A foo() { return struct A { .b = 42 }; } 

如果这不可能:为什么?

是C99为此提供了复合文字( 请参见实时 ):

 return (struct A) { 42 } ; 

C99标准第6.5.2.5节草案中 6.5.2.5 复合文字并说:

后缀表达式由带括号的类型名称后跟括号括起的初始值设定项列表组成,是一个复合文字。 它提供了一个未命名的对象,其值由初始化列表给出。 84)

和:

复合文字的值是初始化列表初始化的未命名对象的值。 如果复合文字出现在函数体外,则该对象具有静态存储持续时间; 否则,它具有与封闭块相关的自动存储持续时间。

并提供了几个例子,包括:

示例3具有指定的初始化器可以与复合文字组合。 使用复合文字创建的结构对象可以传递给函数,而不依赖于成员顺序:

 drawline((struct point){.x=1, .y=1}, (struct point){.x=3, .y=4}); 

gcc在它的扩展部分也有一个很好的文档 ,因为它支持C99以外的这个function以及clang

是的,您可以在C99及更高版本中使用复合文字。

 return (struct A) { .b = 42 }; 

你甚至可以指向他们:

 struct A *a = &(struct A) { .b = 42 }; a->b = 43; 

这些文字比字符串文字“更好”,因为它们是可写的。 当且仅当在文字类型中包含const ,编译器才可以对它们进行汇集。

是的,从C99开始就有可能。 这是一个复合文字。

不过,你的语法错了。 使用:

 (struct A){.b=42} 

要么

 (struct A){42} 

但是,如果无关紧要,请寻求恒定的文字:

 (const struct A){.b=42} 

所有常量文字都受常量池的影响(包括由于历史原因而具有char[]类型的字符串文字)。
任何函数外的常量复合文字和复合文字都有静态存储持续时间,
其余的都有自动存储持续时间(注意返回指针,每次都必须初始化)。

总之,尽可能选择常量文字。