析构函数-复制构造函数-赋值操作符重载-默认构造函数<代码解析>
时间:2022-04-22
本文章向大家介绍析构函数-复制构造函数-赋值操作符重载-默认构造函数<代码解析>,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
通过下面primer中的一道习题,可以更深刻的了解,析构函数,复制构造函数,赋值操作符重载,默认构造函数的使用。
但是我的结果与primer习题解答里面的并不相同,可能是编译器不同的原因导致。
// test1107.cpp : 定义控制台应用程序的入口点。
//
#include "stdafx.h"
#include <iostream>
#include <vector>
using namespace std;
struct Exam{
Exam(){ cout<<"Exam()"<<endl;} //默认构造函数
Exam(const Exam&){ cout<<"Exam(const Exam&)"<<endl;} //复制构造函数
Exam& operator= (const Exam&){ cout<<"Exam& operator"<<endl;return *this;} //赋值操作符
~Exam(){ cout<<"~Exam()"<<endl;}//析构函数
};
void func1(Exam a){}//形参为 exam的对象
void func2(Exam& b){}//形参为 exam的引用
Exam func3(){Exam obj;return obj;} //返回exam的对象
int main(){
cout<<"--------------------1----------------"<<endl;
Exam a; //调用默认的构造函数创建对象a
cout<<"--------------------2----------------"<<endl;
func1(a);// 调用复制构造函数,创建副本传递实参,撤销副本
cout<<"--------------------3----------------"<<endl;
func2(a); //形参为引用,无需传递实参
cout<<"--------------------4----------------"<<endl;
a = func3(); //调用默认构造函数创建局部对象,
//用复制构造函数返回对象副本
//调用析构函数撤销局部对象
//调用赋值函数赋值
//调用析构函数撤销副本
cout<<"--------------------5----------------"<<endl;
Exam *b = new Exam(); //调用默认构造函数创建对象
cout<<"--------------------6----------------"<<endl;
vector<Exam> exec(3); //调用默认构造函数创建对象
//调用赋值构造函数将临时对象复制到每个元素
//调用析构函数撤销
//重复三次
cout<<"--------------------7----------------"<<endl;
delete b; //调用析构,撤销p
cout<<"--------------------8----------------"<<endl;
system("pause");
}
执行结果如下:
- 这是硅谷狂人马斯克对未来做出的11个大胆预测,人工智能比核武器更危险
- 在腾讯云上使用自建DNS
- Spring 4.0.2 学习笔记(1) - 最基本的注入
- 关于女神SQLite的疑惑(2)
- WordPress纯代码仿无觅相关文章图文模式功能(增强版)
- 人工智能时代已悄然来临……
- 人民日报发布周鸿祎署名文章:迎接“大安全”时代的新威胁
- Mono 3.2 上跑NUnit测试
- 为WordPress 文章中的链接自动添加 nofollow标签
- 腾讯刘炽平:海外用户破7000万 微信带开发者“出海”
- 研究称性别不均衡或导致人工智能持有性别偏见
- ASP.NET 2.0加密Web.config 配置文件
- .Net 跨平台可移植类库正在进行
- 掌握机器学习数学基础之概率统计(三)
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法