【C++】面向对象编程(五)初始化、复制、析构

初始化

基类数据成员初始化

如果基类有了实际的数据成员,则我们必须给基类数据成员初始化:为基类提供构造函数(利用这个构造函数初始化基类所声明的所有数据成员)

注意:抽象基类无法定义任何对象(因为抽象基类里纯虚函数没有函数定义)

派生类对象初始化

  • 包含调用其基类的构造函数,再调用自己的构造函数;
  • 子对象包括:
  1. 由基类构造函数初始化的“基类子对象”;
  2. 由派生类构造函数初始化的“派生类子对象”。
  • 派生类的构造函数不仅必须为派生类的数据成员进行初始化,还需要为其基类的数据成员提供适当的值(基类要求我们明确指定调用哪一个构造函数):
inline Fibonacci::Fibonacci(int len,int beg_pos):num_sequence(len,beg_pos,_elems){}

其他做法之“给基类提供默认构造函数”:

//需要把_relems改为指针,且
//每次访问数列(vector)内容前,检查这个指针是否不为null
//vector &_relems;

num_sequence::num_sequence(int len=1,int bp=1,vector<int>*pe=0)
:_length(len),_beg_pos(bp),_pelems(pe){}
//现在编译器会自动调用基类的默认构造函数

复制

  • 如果基类未定义自己的复制构造函数,就直接用默认的成员逐一初始化操作来复制基类的数据成员;
  • 如果基类定义了自己的复制构造函数,派生类的复制构造函数就会调用基类的复制构造函数
  • 派生类和基类的复制赋值运算符同理(注意必须明确调用基类的复制赋值运算符):
Fibonacci& Fibonacci::operator=(const Fibonacci &rhs)
{
	if(this!=&rhs)
	{
		//注意明确调用基类的复制赋值运算符!
		num_sequence::operator=(rhs);
	}
	return *this;
}

析构

基类的析构函数会在派生类的析构函数调用结束后被自动调用,我们无须在派生类中对它做明确的调用操作。

你可能感兴趣的:(C++基础,c++,开发语言,笔记)