C++继承中的对象构造与析构和赋值重载实例分析
发表于:2024-11-28 作者:千家信息网编辑
千家信息网最后更新 2024年11月28日,本文小编为大家详细介绍"C++继承中的对象构造与析构和赋值重载实例分析",内容详细,步骤清晰,细节处理妥当,希望这篇"C++继承中的对象构造与析构和赋值重载实例分析"文章能帮助大家解决疑惑,下面跟着小
千家信息网最后更新 2024年11月28日C++继承中的对象构造与析构和赋值重载实例分析
本文小编为大家详细介绍"C++继承中的对象构造与析构和赋值重载实例分析",内容详细,步骤清晰,细节处理妥当,希望这篇"C++继承中的对象构造与析构和赋值重载实例分析"文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。
一、构造/析构顺序及继承性
class A{private: int _a;public: A(int a = 0): _a(a) { cout << "A()" << this << endl; } ~A() { cout << "~A()"<< this <结论:
1.构造顺序:先构造基类,后构造派生类
2.析构顺序:先析构派生类,后析构基类
二、拷贝构造的继承性
class A{private: int _a;public: A(int a = 0): _a(a) { cout << "A()" << this << endl; } A(const A& src): _a(src._a) { cout << "A(const A& src)"<< this << endl; } ~A() { cout << "~A()"<< this <结论:
1.先调用基类缺省的构造函数,后调用派生类的拷贝构造函数
2.若派生类没有缺省构造函数A(),就会报错
疑惑:如何去调用基类的拷贝构造而不是缺省构造
#includeusing namespace std;class A{private: int _a;public: A(int a = 0) : _a(a) { cout << "A()" << this << endl; } A(const A& src) : _a(src._a) { cout << "A(const A& src)" << this << endl; } ~A() { cout << "~A()" << this << endl; }};class B : public A{private: int _b;public: B(int b) : _b(b), A() { cout << "B()" << this << endl; } B(const B& src) : _b(src._b), A(src) //发生赋值兼容规则(切片) { cout << "B(const B& src)" << this << endl; } ~B() { cout << "~B()" << this << endl; }};int main(){ B b(10); B b1(b); return 0;} 结果:
将B类型src传递给A类型的A(const A& src)拷贝构造函数,发生了赋值兼容规则(切片现象)
三、赋值重载不具有继承性
#includeusing namespace std;class A{private: int _a;public: A(int a = 0) : _a(a) { cout << "A()" << this << endl; } A(const A& src) : _a(src._a) { cout << "A(const A& src)" << this << endl; } A& operator=(const A& src) { if(this != &src) { _a = src._a; cout << "A& operator=(const A& src)" << endl; } } ~A() { cout << "~A()" << this << endl; }};class B : public A{private: int _b;public: B(int b) : _b(b), A() { cout << "B()" << this << endl; } B(const B& src) : _b(src._b), A(src) //发生赋值兼容规则(切片) { cout << "B(const B& src)" << this << endl; } B& operator=(const B& src) { if(this != &src) { _b = src._b; cout << "B& operator=(const B& src)" << endl; } } ~B() { cout << "~B()" << this << endl; }};int main(){ B b1(10); B b2(20); b1 = b2; return 0;} 结论:默认情况下仅仅调用了派生类的对象的赋值重载,并未调用基类的赋值重载。
解决方案:
#includeusing namespace std;class A{private: int _a;public: A(int a = 0) : _a(a) { cout << "A()" << this << endl; } A(const A& src) : _a(src._a) { cout << "A(const A& src)" << this << endl; } A& operator=(const A& src) { if(this != &src) { _a = src._a; cout << "A& operator=(const A& src)" << endl; } } ~A() { cout << "~A()" << this << endl; }};class B : public A{private: int _b;public: B(int b) : _b(b), A() { cout << "B()" << this << endl; } B(const B& src) : _b(src._b), A(src) //发生赋值兼容规则(切片) { cout << "B(const B& src)" << this << endl; } B& operator=(const B& src) { if(this != &src) { *(A*)this = src; //将调用基类赋值重载 _b = src._b; cout << "B& operator=(const B& src)" << endl; } } ~B() { cout << "~B()" << this << endl; }};int main(){ B b1(10); B b2(20); b1 = b2; return 0;} 读到这里,这篇"C++继承中的对象构造与析构和赋值重载实例分析"文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注行业资讯频道。
对象
函数
拷贝
规则
实例
实例分析
C++
分析
文章
结论
继承性
顺序
内容
类型
妥当
思路
情况
新知
方案
更多
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
电子看板软件开发价格
大学生网络安全教育思维导图
软件开发麻将
服务器网上商城
理想汽车车机软件开发工程师
网络安全小组活动策划
暗流涌动 网络安全
败笔网络安全技术技巧
数据核查软件开发
网络安全测评师资格证
筑业软件数据库执行错误怎么办
传统的软件开发模式
秀屿区网络安全
传奇4服务器无反应
国外服务器优惠码
江西管理系统软件开发
应用市场改地区号连不到服务器
三调数据库成果包括哪些数据
天河区正规网络技术开发工艺
财政网络安全手册
炮爷服务器
人工表转换为数据库表
云浮市网络技术公司有几家
数据库系统的作用
如何将html发到服务器上
汕头软件开发学费
计算机网站服务器
网络云平台网络安全发言材料
软件开发基础一定要好吗
探讨医院网络安全方案