构造函数调用序列
Constructor calling sequence
本文关键字:函数调用 更新时间:2023-10-16
示例 1:
#include <iostream>
class A
{
public:
A(int a)
{
std::cout << "A: " << a << 'n';
}
A()
{
std::cout << "A" <<'n';
}
};
class B: public A
{
private:
int b;
A a1;
public:
B(int a, double b)
: a1(a)
{
std::cout << "B: " << b << 'n';
}
};
class C: public B
{
public:
C(int a , double b , char c)
: B(a, b)
{
std::cout << "C: " << c << 'n';
}
};
int main()
{
C c(5, 4.3, 'R');
return 0;
}
输出:
A
A: 5
B: 4.3
C: R
示例 2:
#include <iostream>
class A
{
public:
A(int a)
{
std::cout << "A: " << a << 'n';
}
A()
{
std::cout << "A: " <<'n';
}
};
class B: public A
{
private:
int b;
A a1;
public:
B(int a, double b)
: A(a)
{
std::cout << "B: " << b << 'n';
}
};
class C: public B
{
public:
C(int a , double b , char c)
: B(a, b)
{
std::cout << "C: " << c << 'n';
}
};
int main()
{
C c(5, 4.3, 'R');
return 0;
}
输出:
A: 5
A:
B: 4.3
C: R
我从 CPP 中了解到的是,首先调用基类的构造函数,然后初始化成员,最后调用派生类的构造函数。那为什么我没有得到输出的前 2 行相同?
为什么你期望它们是相同的?在您的第一个示例中,此片段:
B(int a, double b)
: a1(a)
它首先隐式初始化基类(使用默认构造函数),将单个A
输出到终端,然后在初始化成员变量a1
中输出A: 5
。您的代码实际上等效于:
B(int a, double b)
: A(), // implicit
b(), // implicit
a1(a)
第二个例子完全颠倒了:
B(int a, double b)
: A(a)
使用单参数构造函数显式初始化 base(输出A: 5
),然后使用默认构造函数(输出A
)隐式初始化成员变量。此代码等效于:
B(int a, double b)
: A(a),
b(), // implicit
a1() // implicit
是否在构造函数中放置显式初始化代码并不重要 - 首先初始化所有基类,然后初始化所有成员变量。这些初始化要么使用您给出的参数,要么是默认初始化(如果省略它们)。如果省略初始值设定项,并且没有可用的默认构造函数,则编译将失败并显示错误。
相关文章:
- 函数调用中参数的顺序重要吗
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- 变量没有改变?通过向量的函数调用
- 在两个类中共享相同的函数调用,并在不需要时避免空实例化
- 是否有C++编译器选项允许激进地删除所有函数调用,并将参数传递给具有空体的函数
- 我知道函数调用中存在歧义.有没有办法调用foo()函数
- 模板函数调用
- 获取从C++中同一类中的构造函数调用的方法返回的值
- 析构函数调用
- 成员函数调用和C++对象模型
- 使用共享指针的函数调用,其对象应为 const
- C++:编译时检查匹配的函数调用对?
- 函数调用C++中的参数太少
- 来自 DLL 的函数调用 [表观调用的括号前面的表达式必须具有(指向-)函数类型]
- 返回指向对象的指针的函数调用是否为 prvalue?
- C++ 如何重载 [] 运算符并进行函数调用
- 代码的效率. 转到和函数调用
- 是同一作用域的函数部分中的函数调用
- 如何封装一个函数,以便它只能由同一类中的一个其他函数调用?
- 类型擦除的std::function与虚拟函数调用的开销