类
1.this指针。
以下先定义一个Date
C++编译器给每个“非静态的成员函数“增加了一个隐藏 的指针参数,让该指针指向当前对象(函数运行时调用该函数的对象),在函数体中所有“成员变量” 的操作,都是通过该指针去访问。只不过所有的操作对用户是透明的,即用户不需要来传递,编 译器自动完成。
1.1 this指针的特性
- this指针的类型:类类型* const,即成员函数中,不能给this指针赋值。
- 只能在“成员函数”的内部使用
- this指针本质上是“成员函数”的形参,当对象调用成员函数时,将对象地址作为实参传递给 this形参。所以对象中不存储this指针。、
- this指针是“成员函数”第一个隐含的指针形参,一般情况由编译器通过ecx寄存器自动传递,不需要用户传递。想要用户传递的话可以采用如下方法:
可以在成员函数中通过cout<<this(取得是传进来的结构体地址)<<endl 加上this 这样就可以在_year=year前面加上this如this->_year=year。
2 C++与C Stack实现的区别
2.1 C
- 数据与方法是分离的。
- 数据访问控制是自由的,不受控制的。
- C需要自己传递结构体的地址,即要用户维护,但本质上是一样的。
2.2 C++
1. 数据与方法都封装再类里面。
2. 数据访问控制是受到控制的,愿意给你访问的才能访问。
3. C++不需要自己传递结构体地址,即编译器维护好了,但本质上是一样的。
3 构造函数
3.1概念
构造函数是特殊的成员函数,它并不是开辟空间,而是用于初始化且在对象整个生命周期只有一次。
3.2特性
- 函数名与类对象重名
- 没有返回值。不需要定义void
- 对象实例化编译器自动调用对应的构造函数
- 可以函数重载
- 没有显示定义构造函数,C++会默认生成一个无参构造函数,显式定义就不在生成。
- C++把类型分为内置类型和自定义类型。内置类型是语言提供的基本类型int/char/....
自定义类型为struct/union/class/enum...。C++自动生成的默认构成函数不会对内置类型进行初始化。但是会对自定义类型调用它的默认生成函数(构造/析构)。
7.无参构造函数和全缺省构造函数都称为默认构造函数。并且默认构造函数只有一个(调用歧义)。注意:我们没有编写编译器默认生成的构造函数也叫默认构造函数。
无参都可以调用默认构造函数
一般建议,每个类提供一个默认构造函数。
4 析构函数
4.1概念
与构造函数功能相反,析构函数不是完成对对象本身的销毁,局部对象销毁由编译器销毁。它是完成对对象的销毁(如空间的释放),完成对象资源的清理工作。
4.2特性
- 析构函数再类名前加上~
- 对象生命周期结束C++编译系统自动调用
- 无返回值
- 一个类只有一个析构函数,若未显示定义,编译器会自动生成默认的析构函数。Ps:不能函数重载
- 内置类型不做处理,自定义类型会调用默认构造函数。
5 拷贝构造函数
5.1概念
拷贝构造函数:拷贝构造函数只有单个形参,该形参类型是类类对象的引用,适用于已存在的类类对象拷贝给正在创建的类对象。
5.2 特性
1.拷贝构造函数是构造函数的一种函数重载。
2.拷贝构造函数有且只有一个且必须是类类型对象的引用,使用传值方式会引起编译器的报错,引起无穷递归.
为什么内置类型可以直接传值拷贝而自定义类型不行?
假设有两个Stack。自定义类型中要是带有动态数组(int* a)的话,进行传值拷贝只会拷贝4字节,两个Stack指向一个空间,进行析构Stack 1先释放,然后Stck 2又释放出现了错误。而且进行初始化的时候,两个Stack都指向一个空间不对,应该有自己的空间。
3.没有自定义拷贝构造函数,编译器会自动生成拷贝构造函数。自动生成的拷贝构造会进行浅拷贝。浅拷贝就是按照对象在内存存储的字节一一拷贝。
4.默认生成的拷贝构造函数已经可以完成字节序的浅拷贝了。但是对于自定义类型,一旦涉及资源申请,需要自己手动释放,就需要自己写拷贝构造函数。
5.3场景
- 函数参数类型为类类型对象
- 函数返回值为类类型对象
- 给正在创建的类对象进行值拷贝