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++类中,有6个默认成员函数: 构造函数 析构函数 拷贝...
#pragma once // 1. 设计一个不能被拷贝的类/* 解析:拷贝只会放生在两个场景中:拷贝构造函数以及赋值运...
C类型转换 C语言:显式和隐式类型转换 隐式类型转化:编译器在编译阶段自动进行,能转就转,不能转就编译...
//异常的概念/*抛出异常后必须要捕获,否则终止程序(到最外层后会交给main管理,main的行为就是终止) try...
#pragma once /*Smart pointer 智能指针;灵巧指针 智能指针三大件//1.RAII//2.像指针一样使用//3.拷贝问...
目录<future>future模板类成员函数:promise类promise的使用例程:packaged_task模板类例程...