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


    初始化

    基类数据成员初始化

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

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

    派生类对象初始化

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

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

    //需要把_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){}
    //现在编译器会自动调用基类的默认构造函数
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    复制

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

    析构

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

  • 相关阅读:
    成功解决ValueError: cannot reindex from a duplicate axis
    Centos下安装postgreSQL
    循环单链表的头插及尾插实现
    vue3 路由新玩法useRoute 和useRouter
    Docker笔记-08 Docker BuildKit
    Typecho主题 - 一款视频ZeVideo开源主题
    医学专题(6)--多组学在肿瘤分型研究中的应用思路
    20230908-考题记录
    从技术走向管理
    1161 Merging Linked Lists – PAT甲级真题
  • 原文地址:https://blog.csdn.net/weixin_49347928/article/details/133688618