1.类的默认成员函数
构造函数
析构函数
一、类的默认成员函数
1.构造函数
(1)构造函数时特殊的成员函数。构造函数的主要任务并不是开空间创建对象,而是对象实例化时初始化对象。
构造函数的特点:
①函数名与类名相同。
②无返回值。
③对象实例化时系统会自动调用对应的构造函数。
④构造函数可以重载。

由上图可知构造函数可以重载,但是当我们调用d3时发现编译器报错了。因为此时编译器无法区分d3是函数声明还是实例化对象,所以导致了错误的发生。因此我们在调用构造时,要么给足够的参数,要么就别加括号。
⑤如果类中没有显示定义构造函数,则c++编译器会自动生成的构造函数,一旦用户显示,编译器就不会自动生成。
⑥构造函数分为无参构造、全缺省构造和我们不写构造时编译器默认生成的构造函数。这三个中有且只能存在一个,不能同时存在。因为无参和全缺省构造函数虽然构成函数重载,但是调用会产生歧义。

由上图我们可以得出当我们类出现多个构造时,当我们调用默认不传参时,会产生歧义。最好弄成全缺省值。这样可以应对任何一种情况,并将其准确初始化。
⑦我们不写的话,用编译器默认生成的构造,对内置类型(int char double 指针)的初始化时不确定的,看编译器。

我们看到上图类中根本没有写构造函数,此时构造函数直接调用默认构造,这个值时默认生成的,生成随机值,但是在其他编译可能不是这样的结果。那么当我们向生成合适的初始化时,可采取全缺省构造来应对。
2.析构函数
与构造函数功能相反,析构函数不是完成对对象本身的销毁。它是用来函数结束栈帧销毁的。此时就释放了。c++规定对象中会自动调用析构函数,完成对象中的资源清理与释放工作
(1)析构函数名在类名前加~
(2)其中无参数无返回值
(3)一个类只能有一个析构函数
(4)对象生命周期结束自动调用析构函数
(5)析构函数对内置类型成员不做处理,自定类型成员调用析构函数

由上图发现析构函数并不会对数值类型的值作任何的处理。
(6)当我们显示写析构时,对于自定义类型成员也会调用他的析构,所以自定义类型无论什么情况都会自动调用析构。
(7)如果类中没有申请资源时,析构可以不写。有动态内存申请时我们必须自己写析构,否则会出现资源泄露。

由上图可知,我们注释了析构函数,由系统自动生成的析构,此时p1和p2的arr地址没有变成空值,而size和capacity则调用了随机值。这就会造成内存泄露,所以当我们出现需要malloc时,我们一定要自己写析构。
(8)一个局部域的多个对象,c++规定后定义的先析构。


被折叠的 条评论
为什么被折叠?



