我主要对c++中不同初始化的概念感到困惑,特别是在c++11标准中。
我特别感到困惑的是,对象是通过new (相关与否)构造的,并且提供了一个初始化器列表(与用户定义的构造函数匹配),并且构造函数没有初始化所有成员(包括POD和其他类)。
以下是我的困惑。
class B
{
public:
int b1;
int b2;
};
class C
{
public:
int c1;
int c2;
C()
{
c2 = 1234;
}
};
class A
{
public:
int a1;
B a2;
C a3;
A(int a): a1(a){}
};如果我写auto aptr = new A(5),我们能评论一下吗?
aptr->a1、aptr->a2、aptr->a3中每个字段的值是多少?补充:部分混淆来自于初始化中包含的示例
struct A
{
int i;
A() { } // user-provided default ctor, does not initialize i
};
struct B { A a; }; // implicitly-defined default ctor
std::cout << B().a.i << '\n'; // value-initializes a B temporary
// leaves b.a.i uninitialized in C++03
// sets b.a.i to zero in C++11
// (note that B{}.a.i leaves b.a.i uninitialized in C++11, but for
// a different reason: in post-DR1301 C++11, B{} is aggregate-initialization,
// which then value-initializes A, which has a user-provided ctor)其中,B的值初始化似乎触发了设置A.i的A的某些初始化(哪一个是它)。对这个有什么意见吗?
发布于 2019-10-11 06:58:48
aptr->a1、aptr->a2、aptr->a3中每个字段的值是多少?
aptr->a1将拥有5:因为A(int a): a1(a){},而您通过了A(5)。aptr->a2将是一个默认的(编译器语法化)构造的B对象(即聚合类型),具有它的b1和b2垃圾值。aptr->a3将是由您提供的默认构造函数(即C(){ c2 = 1234; })构造的C对象。这意味着c1在a3中将具有垃圾值,而c2将被1234弱化。https://stackoverflow.com/questions/58331484
复制相似问题