博客
关于我
C++-必须知道的类的6个默认成员函数(构造-析构-拷贝构造-操作符重载)
阅读量:275 次
发布时间:2019-03-01

本文共 2774 字,大约阅读时间需要 9 分钟。

文章目录

1. 类的6个默认成员函数

  如果一个类中什么成员都没有,简称为空类,但是并不是什么都没有,在任何一个类中都会默认生成6个默认成员函数。

2. 构造函数

2.1 作用

  构造函数主要是用来进行类的初始化

2.2 特点

  1.名字和类的名字相同

  2.创建类类型对象时由编译器自动调用
  3.在对象的生命周期内只调用一次

2.3 特性

  1.构造函数的主要任务并不是开空间创建对象,而是初始化对象。

  2.函数名和类名相同。
  3.无返回值。
  4.对象实例化时编译器自动调用对应的构造函数。
  5.构造函数可以重载。
  6.如果类中没有显示定义构造函数,C++编译器默认生成一个无参的默认构造函数,但当用户显示定义编译器将不再生成,如果用户想要只能自己手动定义。
  7.无参数的构造函数和全缺省的构造函数都称为默认构造函数,默认构造函数只能有一个。

2.4 代码

#include 
using namespace std;class Date{public: //1.无参构造函数 Date() {} //2.带参数构造函数 Date(int year, int month, int day) { _year = year; _month = month; _day = day; } void SetDate(int year, int month, int day) { _year = year; _month = month; _day = day; } void Display() { cout << _year << "-" << _month << "-" << _day << endl; }private: int _year; int _month; int _day;};int main(){ Date d1, d2; d1.SetDate(2021, 4, 6); d1.Display(); d2.SetDate(2021, 4, 6); d2.Display(); Date d3; Date d4(); return 0;}

3. 析构函数

3.1 作用

  对象在销毁的时候会调用析构函数,完成类的一些清理工作。

3.2 特性

  1.析构函数名是在类名前面加上一个字符~。

  2.无参数,无返回值。
  3.一个类只有一个析构函数,如果没有显示定义,系统会默认生成一个析构函数。
  4.对象生命周期结束时,C++编译器系统会自动调用析构函数。

3.3 代码

class SeqList{public:	SeqList(int capacity = 10)	{		_pData = (DataType*)malloc(capacity * sizeof(DataType));		assert(_pData);		_size = 0;		_capacity = capacity;	}	~SeqList()	{		if (_pData)		{			free(_pData);			_pData = NULL;			_capacity = 0;			_size = 0;		}	}private:	int* _pData;	size_t _size;	size_t _capacity;};

class String{public:	String(const char* str = "jack")	{		_str = (char*)malloc(strlen(str) + 1);		strcpy(_str, str);	}	~String()	{		cout << "~String()" << endl;		free(_str);	}private:	char* _str;};class Person{private:	String _name;	int _age;};

4. 拷贝构造函数

4.1 概念

  构造函数:只有单个形参,该形参时对本类类型对象的引用(一般常用const修饰),在用已存在的类类型对象创建新对象时由编译器自动调用。

4.2 特征

  1.拷贝构造函数时构造函数的一个重载形式

  2.拷贝构造函数的参数只有一个且必须使用引用传参,使用传值方式会引发无限递归调用。
  3.若未显示定义,系统生成默认的拷贝构造函数,默认的拷贝构造函数对象按照内存存储按字节序完成拷贝,这种拷贝我们叫做浅拷贝或者值拷贝。

4.3 代码

#include 
class Date{public: Date(int year = 1900, int month = 1, int day = 1) { _year = year; _month = month; _day = day; } Date(const Date& d) { _year = d._year; _month = d._month; _day = d._day; }private: int _year; int _month; int _day;};int main(){ Date d1; Date d2(d1); return 0;}

5. 赋值操作符重载

5.1 运算符重载

5.1.1 概念

  C++为了增强代码的可读性引入运算符重载,运算符重载是具有特殊函数名的函数,也具有其返回值类型,函数名字以及参数列表,其返回值类型与参数列表与普通的函数类似。

  函数名字为:关键字operator后面接需要重载的运算符符号。
  函数原型:返回值类型,operator操作符(参数列表)
注意:
  1.不能通过连接其他符号来创建新的操作符:比如operator@。
  2.重载操作符必须有一个类类型或者枚举类型的操作数。
  3.用于内置类型的操作符,其含义不能改变,比如整型。
  4.作为类成员的重载函数时,其形参看起来比操作数数目少1成员函数的操作符有一个默认的形参this,限定为第一个形参。
  5…*,::,sizeof,?:,.注意以上5个运算符不能重载。

5.2 赋值运算符重载

5.2.1 特点

  1.参数类型。

  2.返回值。
  3.检测是否自己给自己赋值。
  4.返回*this。
  5.一个类如果没有显示定义赋值运算符重载,编译器也会生成一个,完成对象按照字节序的值拷贝。

6. const成员

6.1 概念

  将const修饰的类成员函数称为const成员函数,const修饰类成员函数,实际修饰该成员函数隐含的this指针,表明在该成员函数中不能对类的任何成员进行修改。

转载地址:http://unno.baihongyu.com/

你可能感兴趣的文章
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_插入修改删除增量数据实时同步_通过分页解决变更记录过大问题_01----大数据之Nifi工作笔记0053
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表或全表增量同步_实现指定整库同步_或指定数据表同步配置_04---大数据之Nifi工作笔记0056
查看>>
NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现update数据实时同步_实际操作05---大数据之Nifi工作笔记0044
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_生成插入Sql语句_实际操作02---大数据之Nifi工作笔记0041
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_不带分页处理_01_QueryDatabaseTable获取数据_原0036---大数据之Nifi工作笔记0064
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
查看>>
NIFI从Oracle11G同步数据到Mysql_亲测可用_解决数据重复_数据跟源表不一致的问题---大数据之Nifi工作笔记0065
查看>>
NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
查看>>
nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
查看>>
NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
查看>>
NIFI分页获取Postgresql数据到Hbase中_实际操作---大数据之Nifi工作笔记0049
查看>>
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
NIFI同步MySql数据源数据_到原始库hbase_同时对数据进行实时分析处理_同步到清洗库_实际操作06---大数据之Nifi工作笔记0046
查看>>
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>
【Flink】Flink 1.9 版本 web UI 突然没有日志
查看>>