c – typedef struct:默认初始化

前端之家收集整理的这篇文章主要介绍了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&C++相关文章