c++继承构造析构调用原则以及特殊变量处理

一、继承中的构造析构调用原则

  1.子类对象在创建时会首先调用父类的构造函数

  2.父类构造函数执行结束后,执行子类构造函数

  3.当父类构造函数有参数时,需要在子类的初始化列表中显示调用;

  4.析构函数调用的先后顺序与构造函数相反

二、继承与组合混搭时,构造与析构的调用原则

  1.先析构父类,再构造成员变量,最后构造自己

  2.先析构自己,在析构成员变量,最后析构父类(先析构的对象,后释放)

三、继承中同名成员变量处理方法

  1、当子类成员变量与父类的成员变量同名时,子类依然从父类继承同名成员,且同名成员存储在不能的内存中,在子类中通过作用域分析符::进行同名成员区分,默认使用子类成员变量;

四、继承中,父类的static变量

  1.static函数也遵循3个访问原则

  2.static要初始化,告诉编译器分配内存;

  3.构造函数默认为private,被继承时定义对象会编译报错(单例时不会报错)

原文地址:https://www.cnblogs.com/jly594761082/p/10421642.html

时间: 2024-08-09 10:24:43

c++继承构造析构调用原则以及特殊变量处理的相关文章

C++类构造析构调用顺序训练(复习专用)

//对象做函数参数 //1 研究拷贝构造 //2 研究构造函数,析构函数的调用顺序 //总结 构造和析构的调用顺序 #include "iostream" using namespace std; class ABCD { //this() public: ABCD(int a, int b, int c) { this->a = a; this->b = b; this->c = c; printf("ABCD() construct, a:%d,b:%d

构造 析构调用时机

#include "stdafx.h" class MyClass{public: MyClass() {  printf("MyClass"); } ~MyClass() {  printf("~MyClass"); } }; int _tmain(int argc, _TCHAR* argv[]){ MyClass my;//系统会为你调用析构 MyClass *my=new MyClass://需要手动delete才会调用析构,否则内存泄露

Effective C++笔记:构造/析构/赋值运算

条款05:了解C++默默编写并调用哪些函数 默认构造函数.拷贝构造函数.拷贝赋值函数.析构函数构成了一个类的脊梁,只有良好的处理这些函数的定义才能保证类的设计良好性. 当我们没有人为的定义上面的几个函数时,编译器会给我们构造默认的. 当成员变量里有const对象或引用类型时,编译器会不能合成默认的拷贝赋值函数:当一个基类把它的拷贝赋值函数定义为private时,它的派生类也不无生成默认的拷贝赋值函数,因为它无法完成基类成份的赋值. 条款06:若不想使用编译器自动生成的函数,就该明确拒绝 将拷贝构

【Effective C++】构造/析构/赋值运算

条款05:了解C++默默编写并调用哪些函数 默认构造函数.拷贝构造函数.拷贝赋值函数.析构函数构成了一个类的脊梁,只有良好的处理这些函数的定义才能保证类的设计良好性. 当我们没有人为的定义上面的几个函数时,编译器会给我们构造默认的. 当成员变量里有const对象或引用类型时,编译器会不能合成默认的拷贝赋值函数:当一个基类把它的拷贝赋值函数定义为private时,它的派生类也不无生成默认的拷贝赋值函数,因为它无法完成基类成份的赋值. 条款06:若不想使用编译器自动生成的函数,就该明确拒绝 将拷贝构

c++笔记:const、初始化、copy构造/析构/赋值函数

构造函数 Default构造函数:可被调用而不带任何实参的构造函数,没有参数或每个参数都有缺省值.如: class A { public: A(); }; 将构造函数声明为explicit,可阻止它们被用来执行隐式类型转换,但仍可用来进行显示类型转换.如: class B { public: explicit B(int x = 0, bool b = ture); }; copy构造函数:用于以同型对象初始化自我对象,以passed by value的方式传递对象:· copy assignm

《Effective C++》第2章 构造/析构/赋值运算(1)-读书笔记

章节回顾: <Effective C++>第1章 让自己习惯C++-读书笔记 <Effective C++>第2章 构造/析构/赋值运算(1)-读书笔记 <Effective C++>第8章 定制new和delete-读书笔记 条款05:了解C++默默编写并调用哪些函数 当C++处理过一个空类后,编译器就会为其声明(编译器版本的):一个拷贝构造函数.一个拷贝赋值运算符和一个析构函数.如果你没有声明任何构造函数,编译器还会声明一个默认构造函数.所有这些函数都被声明为pub

利用C++对象确定性析构的原则来解析单例模式

最近发现MDT推出去的系统的有不同问题,其问题就不说了,主要是策略权限被域继承了.比如我们手动安装的很多东东都是未配置壮态,推的就默认为安全壮态了,今天细找了一下,原来把这个关了就可以了. 利用C++对象确定性析构的原则来解析单例模式

C++ map.insert 传参类型不同,构造/析构次数不同

1. 传参方式 使用 insert 为 map 插值时,insert 的传参包含以下几种可能: make_pair 生成对象 pair(key_type, value_type) 生成对象 pair(const key_type, value_type) 生成对象 map<key_type, value_type>::value_type 生成对象 不同的传参,导致不同次数的构造 / 析构函数调用. 2. 测试代码与结果 /* 在 map 中不同的 insert 传参类型,导致的不同次数的构造

《Effective C++》第2章 构造/析构/赋值运算(2)-读书笔记

章节回顾: <Effective C++>第1章 让自己习惯C++-读书笔记 <Effective C++>第2章 构造/析构/赋值运算(1)-读书笔记 <Effective C++>第2章 构造/析构/赋值运算(2)-读书笔记 <Effective C++>第8章 定制new和delete-读书笔记 条款09:绝不在构造和析构过程中调用virtual函数 你不该在构造和析构函数期间调用virtual函数,因为这样的调用不会带来你预期的结果. (1)在der