绪论
时间的步伐有三种:未来姗姗来迟,现在像箭一样飞逝,过往永远静立不动。本章是类和对象的一个收尾篇,相信通过这三篇类和对象的学习,应该你已经更加清楚了解了C++的类和对象。
话不多说安全带系好,发车啦(建议电脑观看)。
思维导图:
要XMind思维导图的话可以私信哈
目录
1.再谈构造函数
1.1初始化列表
1.2:explicit
2.static
3.友元
3.2友元类
4.内部类
5.匿名对象
1.再谈构造函数
知识点:
前面我们已经学习过来构造函数,他是用来给对我们的成员进行初始化的。如:
Date(int year = 1970, int month = 1, int day = 1) { _year = year; _month = month; _day = day; }
而因为在一些特殊的情况下,构造函数无法完成一些活动,所以不能只使用构造函数
因此C++又提出了一个新概念:
1.1初始化列表
知识点:
如像:引用、const变量 (他们都是需要在定义的时候进行初始化,否则就无法正常的使用)、以及自定义类型(当没有默认构造函数的时)他们都不能直接通过构造函数来完成
在一个对象定义的时候其成员变量是在初始化列表中进行定义的
语法:
基本和构造函数差不多,在其中间插入初始化列表
Date(...)
:成员变量(初始值/变量)
, 成员变量(.....)
....
,成员变量(.....)
{
......
}
并且对于成员变量来说,其在c++11打的补丁,可以给成员缺省值,实际上就是把这个个缺省值给初始化列表
实例如下:
class B { public: /*B() { _a = 1; }*/ B(int a) :_a(a) { _a = a; } private: int _a; }; class A { public: A(int& a, int i) //而对于成员的初始化是在初始化列表处完成的 :_a(a) , _i(1) ,bb(10)//此时因为没有默认构造,所以我们只能去调用构造函数,所以需要我们使用初始化列表来进行传参 ,a()//内置类型 { } private: //对于引用和常变量来说他们必须在定义的时候进行初始化,否则就无法使用 int& _a; const int _i; //而对于自定义结构来说,也是通过初始化列表来进行初始化的 B bb; //内置类型的缺省值,其实就是给初始化列表的 int a = 1; }; int main() { int n = 0; A(n,10); return 0; }
细节:
对于初始化列表,当你不写时,操作系统也会默认的生成一个,并且肯定会走初始化列表过一下
对于构造函数来说,初始化列表固然很强能解决大部分初始化时的定义问题,但不能完全解决是有问题
对于自定义结构来说也是同理他会自动去通过初始化列表来进行调用自身的构造函数,但是如果是内置类型当不给缺省值/不在构造函数内赋值的话,他并不会自动的初始化
成员变量是通过 声明的顺序进行初始化 的和初始化列表的顺序无关
对于4来说,我们就建议声明的顺序和定义的顺序保持一致
练习:
通过初始化列表让没有默认构造的自定义类型可以进行初始化(此时有的是非默认构造的构造函数)。
1.2:explicit
在对于下面这种代码来说,是存在隐式类型转换的
A a = 3; const A& a = 3;
并且在编译器下会把构造+构造这种在一行的多次构造的情况优化成只进行一次构造
假如是分开行就不行了
假如我们不想让其可以进行隐式类型转换的话,就可以在构造函数全面加上explicit
使用后就会标红