继承,基构造函数被调用
C++ - Inheritance, which base constructor is called?
我写了一个测试程序:
#include <iostream>
class base
{
public:
base()
{
std::cout << "base 1" << std::endl;
}
base(int a)
{
std::cout << "base a=" << a << std::endl;
}
};
class child : public base
{
public:
child()
{
std::cout << "child" << std::endl;
}
};
int main(int argc, char* argv[])
{
child c;
return 0;
}
程序输出如下内容:
$ ./a.out
base 1
child
是否有任何可能的方法发送整数参数到基类,从而调用基类构造函数的另一种形式?
在base只有一个构造函数的情况下,我得到一个编译错误:candidate expects 1 argument, 0 provided
,正如您可能期望的那样。但是如果我给构造函数一个默认参数,比如:
base(int a = 10)
则我的程序编译并运行,输出为:base a=10
。(有趣吗?)
是否有办法传递a
的变量值?
可以在派生类的构造函数的初始化列表中调用基类构造函数
child() : base( 10 )
{
std::cout << "child" << std::endl;
}
另一种方法是在派生类
中放置using声明。class child : public base
{
public:
using base::base;
child()
{
std::cout << "child" << std::endl;
}
};
在这种情况下,派生类也将具有带参数的构造函数,该构造函数将使用基类的参数调用相应的构造函数。
下面是一个示范程序
#include <iostream>
int main()
{
class base
{
public:
base()
{
std::cout << "base 1" << std::endl;
}
base(int a)
{
std::cout << "base a=" << a << std::endl;
}
};
class child : public base
{
public:
using base::base;
child()
{
std::cout << "child" << std::endl;
}
};
child c( 10 );
}
程序输出为
base a=10
您可以使用:
语法调用非默认构造函数:
child() : base(1)
相关文章:
- 在c++中使用向量时,如何调用构造函数和析构函数
- C++:考虑但不调用构造函数的特殊性
- 对象实例化调用构造函数的次数太多
- 我使用向量来创建类对象列表.初始化向量时如何使用参数调用构造函数?
- C ++:通过大括号调用构造函数?
- 不能调用构造函数
- 赋值 boost::intrusive_ptr 而不调用构造函数?
- 在模板化类的构造函数中调用构造函数
- 如何为 std::vector 分配内存,然后稍后为某些元素调用构造函数?
- 为什么从另一个构造函数内部调用C++构造函数不修改类变量?
- 静态 std::map instatiation 在类的方法中调用构造函数吗?
- 有没有一种简单的方法可以在对象向量上调用构造函数?
- 我不明白在这个例子中什么时候调用构造函数
- 调用c++构造函数的不同方法
- 调用构造函数与将内联常量定义为默认参数
- 如何通过 Rust FFI 调用C++构造函数?
- "new"运算符是否总是调用构造函数?
- 无法调用构造函数
- 使用 "()" 调用构造函数不同于"{}"
- 确定是调用构造函数还是强制转换运算符的因素