c – typedef struct:默认初始化

typedef struct foo
{
    bool my_bool;
    int my_int;
} foo;

在上面的例子中,我明白my_bool将被随机初始化为true或false,但是my_int呢?我假设my_int将认初始化为0,但似乎不是这样.

以这种方式定义结构似乎与初始化列表不兼容,那么最好的方法是将my_bool和my_int分别初始化为false和0?

解决方法

类型不会被“初始化”.只有某些类型的对象被初始化.它们如何和何时被初始化取决于如何和在何处定义相应的对象.你没有提出任何对象在你的问题的定义,所以你的问题本身并不是很有意义 – 它缺乏必要的上下文.

例如,如果定义foo类型的静态对象

static foo foo_object; // zeros

它将自动进行零初始化,因为具有静态持续时间的所有对象始终自动为零初始化.

如果在没有初始化程序的情况下定义了类型为foo的自动对象,它将保持未初始化

void func()
{
   foo foo_object; // garbage
}

如果使用聚合初始化程序定义类型为foo的自动对象,则它将根据该初始化程序进行初始化

void func()
{
   foo foo_object1 = { 1,2 }; // initialized
   foo foo_object2 = {}; // initialized with zeros
}

如果您使用新的对象分配对象,并且不提供初始化器,则它将保持未初始化

foo *p = new foo; // garbage in `*p`

但是如果你使用()初始化器,它将被零初始化

foo *p = new foo(); // zeros in `*p`

如果使用foo()表达式创建一个类型为foo的临时对象,该表达式的结果将被初始化为零

bool b = foo().my_bool; // zero
int i = foo().my_int; // zero

所以,在你的具体情况下,初始化细节依赖于你现在创建的类型的对象,而不是你的类型本身.您的类型本身没有固有的初始化设施,并且不会以任何方式干扰初始化.

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...