[C++]类:合成的默认构造函数与内置类型数据成员

版权声明:未经博主同意不得转载 https://blog.csdn.net/ycwwl1993/article/details/89470061

  C++ primer 第五版中有这样一句话:“如果类包含有内置类型的成员,则只有当这些成员全都被赋予了类内的初始值时,这个类才适合于使用合成的默认构造函数”,这篇博文我们讲解一下这句话的内在含义。

#include<iostream>
#include<string>
class NoDefault{
public:
    std::string str;
    int a;
    void CoutNoVal(){
        std::cout << a << std::endl;
    }
};
NoDefault a;
int main(){
    NoDefault c;
    a.CoutNoVal();//此时输出为0
    c.CoutNoval();//此时c.a初始化是未定义的,与函数体内的内置类型初始化相同
    return 0;
}

从代码上看,a 与 c 相比,a 被定义在函数体内,而 c 被定义在函数体内,a 的内置类型成员被默认初始化,c 没有执行默认初始化。
综合以上内容,对于类内的内置类型数据成员,当类类型对象是全局变量时,合成的默认构造函数会被执行,但当类类型对象是一个局部变量时,合成的默认构造函数不会默认初始化其内置类型的数据成员。
所以说,“如果类包含有内置类型的成员,则只有当这些成员全都被赋予了类内的初始值时,这个类才适合于使用合成的默认构造函数”。
这时,我们可以给这些内置类型的数据成员一个类内初始值,或者定义一个自己的默认构造函数。
参考文献:《C++ primer 第五版》

猜你喜欢

转载自blog.csdn.net/ycwwl1993/article/details/89470061