C++ 子类构造函数的使用
来源:互联网 发布:好的健身软件 编辑:程序博客网 时间:2024/06/05 02:56
构造方法用来初始化类的对象,与父类的其它成员不同,它不能被子类继承(子类可以继承父类所有的成员变量和成员方法,但不继承父类的构造方法)。因此,在创建子类对象时,为了初始化从父类继承来的数据成员,系统需要调用其父类的构造方法。
如果没有显式的构造函数,编译器会给一个默认的构造函数,并且该默认的构造函数仅仅在没有显式地声明构造函数情况下创建。
构造原则如下:
1. 如果子类没有定义构造方法,则调用父类的无参数的构造方法。
2. 如果子类定义了构造方法,不论是无参数还是带参数,在创建子类的对象的时候,首先执行父类无参数的构造方法,然后执行自己的构造方法。
3. 在创建子类对象时候,如果子类的构造函数没有显示调用父类的构造函数,则会调用父类的默认无参构造函数。
4. 在创建子类对象时候,如果子类的构造函数没有显示调用父类的构造函数且父类自己提供了无参构造函数,则会调用父类自己的无参构造函数。
5. 在创建子类对象时候,如果子类的构造函数没有显示调用父类的构造函数且父类只定义了自己的有参构造函数,则会出错(如果父类只有有参数的构造方法,则子类必须显示调用此带参构造方法)。
6. 如果子类调用父类带参数的构造方法,需要用初始化父类成员对象的方式,比如:
#include
class animal
{
public:
animal(int height, int weight)
{
cout<<"animal construct"<<ENDL;
}
…
};
class fish:public animal
{
public:
fish():animal(400,300)
{
cout<<"fish construct"<<ENDL;
}
…
};
void main()
{
fish fh;
}
在fish类的构造函数后,加一个冒号(:),然后加上父类的带参数的构造函数。这样,在子类的构造函数被调用时,系统就会去调用父类的带参数的构造函数去构造对象。
- [C++]子类的构造函数
- C++ 子类构造函数的使用
- 子类的构造函数
- C++_子类与基类的构造函数问题
- C++子类的构造函数
- 子类使用构造函数初始化父类的私有数据
- 在子类构造函数中使用super()
- 虚基类的子类的构造函数
- 【c++】友元关系和子类函数构造函数的写法
- 父类中调用子类构造函数实例化子类的实现
- 父类中调用子类构造函数实例化子类的实现
- 父类中调用子类构造函数实例化子类的实现
- c++中子类的构造函数
- 子类重写父类的构造函数
- 基类中包含子类的构造函数......
- 子类和父类的构造函数
- 子类调用父类的构造函数
- C++中子类的构造函数
- const 的称谓:常量?
- Oracle Database 12.1中rman show all的新变化
- 第二篇
- WIN32,GetBitmapBits与GetPixel
- 利用混合高斯模型实现视频中运动目标与背景的分离
- C++ 子类构造函数的使用
- 网络传输过程
- 跟我一起写 Makefile(四)
- C++高级进阶
- CentOS下连VisualSVN服务器时报"Key usage violation"错误的解决方案
- Zookeeper与Kafka集群搭建
- Ubuntu Server下配置UTF-8中文/英文环境
- 【数据运营】海盗指标体系计算
- powerdesigner 12.5 数据类型