【C++】【类和对象】拷贝构造函数

1.拷贝构造函数的特性:

1.拷贝构造函数用来构造一个与已存在对象一摸一样的对象
它只有
单个形参
,该形参是对本类类型对象的引用(一般常用const修饰),在用已存在的类类型对象创建新对象时由编译器自动调用。
2.拷贝构造函数是构造函数的一种重载形式。
3.形参只有一个(不包括隐含的this指针),且必须是类类型对象的引用,否则会发生
无限递归

#include<iostream>
using namespace std;class Date
{
public:Date(int year, int month, int day){_year = year;_month = month;_day = day;}Date(const Date& d)//错误写法:Date(const Date d){_year =d._year;_month = d._month;_day = d._day;}void Print(){cout << _year << "/" <<_month << "/" << _day << endl;}
private:int _year;int _month;int _day;
};
int main()
{Date d1(2024,2,6);Date d2(d1);d1.Print();d2.Print();
}

错误写法会引发无限递归:
在这里插入图片描述
4. 若未显式定义,编译器会生成默认的拷贝构造函数。 默认的拷贝构造函数对象按内存存储按字节序完成拷贝,这种拷贝叫做浅拷贝,或者值拷贝

#include<iostream>
using namespace std;
class Time
{
public:Time(int hour=1,int minute=1,int second=1){_hour = hour;_minute = minute;_second = second;cout << "Time()" << endl;}Time(const Time& d){_hour = d._hour;_minute = d._minute;_second = d._second;cout << "Time(const Time& d)" << endl;}
private:int _hour;int _minute;int _second;
};
class Date
{
private:int _year;int _month;int _day;Time _t;
};
int main()
{Date d1;Date d2(d1);
}

在这里插入图片描述
从运行结果可以看出::在编译器生成的默认拷贝构造函数中,内置类型是按照字节方式直接拷贝的,而自定义类型调用其拷贝构造函数完成拷贝的

5.深拷贝
看下面一段代码:

#include<iostream>
using namespace std;
class Stack
{
public:Stack(size_t capacity=5){_arry = (int*)malloc(sizeof(int) * capacity);_capacity = capacity;_size = 0;}void Push(int data){_arry[_size] = data;_size++;}~Stack(){if (_arry){free(_arry);_arry = nullptr;_size = 0;_capacity = 0;}}
private:int _size;int _capacity;int* _arry;
};
int main()
{Stack s1;s1.Push(1);s1.Push(2);s1.Push(3);s1.Push(4);Stack s2(s1);return 0;
}

在这里插入图片描述
程序崩溃的原因:s2是s1的拷贝,s1的_arry和s2的_arry指向同一块空间,根据析构函数调用的顺序可知,s2的_arry空间先被释放,也就是两者共同指向的空间被释放了,此时s1成为野指针。s2的析构函数调用完以后,s1的析构函数接着被调用,一块空的空间又被释放了一次,所以此时程序崩溃。
在这里插入图片描述
在这里插入图片描述
用深拷贝改写正确:

class Stack
{
public:Stack(size_t capacity = 5){_arry = (int*)malloc(sizeof(int) * capacity);_capacity = capacity;_size = 0;}Stack(const Stack&s){//重新开辟一块空间:int* tmp = (int*)malloc(sizeof(int) * s._capacity);if (tmp == nullptr){perror("malloc fail");exit(-1);}memcpy(tmp, s._arry, sizeof(int) * s._size);_arry = tmp;_size = s._size;_capacity = s._capacity;}void Push(int data){_arry[_size] = data;_size++;}~Stack(){if (_arry){free(_arry);_arry = nullptr;_size = _capacity = 0;}}
private:int _size;int _capacity;int* _arry;
};
int main()
{Stack s1;s1.Push(1);s1.Push(2);s1.Push(3);s1.Push(4);Stack s2(s1);return 0;}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/673051.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

nginx简单配置四种携带/时的拼接关系

一、代理静态文件 1、 当 location 尾部有 /&#xff0c;且代理地址尾部也有 / 时&#xff1a;&#xff08;常用&#xff09; location /test11/ {root /usr/local/nginx/html/; } 则访问 http://ip/test11/aaa&#xff0c;实际访问的是/usr/local/nginx/html/aaa2、 当…

Flask 入门7:使用 Flask-Moment 本地化日期和时间

如果Web应用的用户来自世界各地&#xff0c;那么处理日期和时间可不是一个简单的任务。服务器需要统一时间单位&#xff0c;这和用户所在的地理位置无关&#xff0c;所以一般使用协调世界时&#xff08;UTC&#xff09;。不过用户看到 UTC 格式的时间会感到困惑&#xff0c;他们…

数据库-MySQL 实战项目——房屋租赁管理系统数据库设计与实现(附源码)

一、前言 需求&#xff1a; 房屋租赁管理系统主要完成功能为&#xff1a; 房屋信息管理出租者信息管理求租者信息管理房屋出租信息管理系统管理&#xff08;员工信息管理、绩效管理等&#xff09; 备注&#xff1a; 1. 一个房屋有多个求租者。&#xff08;一对多&#xff0…

【10秒极速开服】幻兽帕鲁全自动部署服务器教程

幻兽帕鲁太火了&#xff0c;官方palworld服务器不稳定&#xff1f;不如自建服务器&#xff0c;基于腾讯云幻兽帕鲁服务器成本32元全自动部署幻兽帕鲁服务器&#xff0c;超简单有手就行&#xff0c;全程自动化一键部署10秒钟即可搞定&#xff0c;无需玩家手动部署幻兽帕鲁游戏程…

Agile Initiative, Epic, and Story/Task

Stories, also called “user stories,” are short requirements or requests written from the perspective of an end user. stories are something the team can commit to finish within a one- or two-week sprint.Epics are large bodies of work that can be broken do…

设计模式总结复盘-面试篇-20题必看

软件设计模式是前辈们代码设计经验的总结&#xff0c;可以反复使用。设计模式共分为3大类&#xff0c;创建者模式(6种)、结构型模式(7种)、行为型模式(11种)&#xff0c;一共24种设计模式&#xff0c;软件设计一般需要满足7大基本原则。 目录 面试题总结复盘篇 1.1、介绍以下…

网络流问题求解及Gurobi+Python代码(最大流/最小成本网络流/多商品网络流)

目录 1.最大流问题 1.1 问题描述 1.2 Ford-Fulkerson算法 1.3 Gurobi测试 2.最小成本网络流问题 2.1 问题描述 2.2 供应链规划案例 3.多商品网络流问题 3.1 问题描述及模型 3.2 Gurobi测试 Gurobi求解代码&#xff1a;GitHub - bujibujibiuwang/Network-Flow-Probl…

机器学习--K近邻算法,以及python中通过Scikit-learn库实现K近邻算法API使用技巧

文章目录 1.K-近邻算法思想2.K-近邻算法(KNN)概念3.电影类型分析4.KNN算法流程总结5.k近邻算法api初步使用机器学习库scikit-learn1 Scikit-learn工具介绍2.安装3.Scikit-learn包含的内容4.K-近邻算法API5.案例5.1 步骤分析5.2 代码过程 1.K-近邻算法思想 假如你有一天来到北京…

代码随想录算法训练营第42天 | 01背包问题理论基础 + 416.分割等和子集

今日任务 01背包问题&#xff0c;你该了解这些&#xff01; 01背包问题&#xff0c;你该了解这些&#xff01; 滚动数组 416. 分割等和子集 01背包问题 二维数组 理论基础&#xff1a;代码随想录 题目链接&#xff1a;题目页面 01 背包 有n件物品和一个最多能背重量为w 的…

【C++】组合数

题目描述 组合数表示的是从n个物品中选出m个物品的方案数。举个例子&#xff0c;从 (1, 2, 3) 三个物品中选择两个物品可以有 (1, 2)&#xff0c;(1, 3)&#xff0c;(2, 3) 这三种选择方法。 根据组合数的定义&#xff0c;我们可以给出计算组合数的一般公式&#xff1a; 其中…

Qt::invokeMethod

Qt::invokeMethod 是 Qt 框架中的一个函数&#xff0c;用于在指定的对象上调用指定的方法。这个函数通常用于实现跨线程的方法调用&#xff0c;因为在 Qt 中&#xff0c;直接在不同线程中调用对象的方法是不安全的。invokeMethod 可以确保方法的调用是在目标对象所在的线程上执…

常用的数据库SQL语句使用大全

SQL&#xff08;Structured Query Language&#xff0c;结构化查询语言&#xff09;是用于管理和操作关系数据库管理系统的标准编程语言。SQL语句可以执行各种操作&#xff0c;如查询、更新、插入和删除数据库中的数据。下面详细介绍SQL语句的分类和使用方法&#xff1a; 1. S…

Nginx反向代理实现与配置

目录 Nginx 反向代理Nginx反向代理配置 Nginx 反向代理 Nginx 可以充当反向代理服务器&#xff0c;将客户端请求转发到后端的多个服务器上&#xff0c;并将响应返回给客户端。 Nginx作为反向代理服务器的工作原理如下&#xff1a; 客户端发送请求&#xff1a;当客户端&#…

C++ 日期计算器

日期计算器 概要 Date类的规划Date类的实现Date 构造函数Date 拷贝构造函数~Date 析构函数GetMonthDay 求某年某月的天数operator 赋值操作符重载operator 加等操作符重载operator 加号操作符重载operator- 减等操作符重载operator- 减法操作符重载 &#xff08;日期 - 天数&am…

2023年第四季度硬盘容量强势增长9%

在2023年第四季度&#xff08;CQ4 23&#xff09;&#xff0c;硬盘驱动器&#xff08;HDD&#xff09;市场的总容量出货量环比增长9%&#xff0c;达到214EB&#xff0c;而单位出货量保持在2900万块不变。其中&#xff0c;近线存储&#xff08;Nearline&#xff09;硬盘的容量出…

Java基于微信小程序的驾校报名小程序,附源码

博主介绍&#xff1a;✌程序员徐师兄、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专栏推荐订阅&#x1f447;…

JVM双亲委派机制

双亲委派模型是一种组织类加载器之间关系的一种规范,他的工作原理是:如果一个类加载器收到了类加载的请求,它不会自己去尝试加载这个类,而是把这个请求委派给父类加载器去完成,这样层层递进,最终所有的加载请求都被传到最顶层的启动类加载器中,只有当父类加载器无法完成这个加载…

基于SSM的实习管理系统(有报告)。Javaee项目。ssm项目。

演示视频&#xff1a; 基于SSM的实习管理系统&#xff08;有报告&#xff09;。Javaee项目。ssm项目。 项目介绍&#xff1a; 采用M&#xff08;model&#xff09;V&#xff08;view&#xff09;C&#xff08;controller&#xff09;三层体系结构&#xff0c;通过Spring Spri…

Verilog刷题笔记19

题目&#xff1a; A common source of errors: How to avoid making latches When designing circuits, you must think first in terms of circuits: I want this logic gate I want a combinational blob of logic that has these inputs and produces these outputs I want…

【高阶数据结构】B-树详解

文章目录 1. 常见的搜索结构2. 问题提出使用平衡二叉树搜索树的缺陷使用哈希表的缺陷 3. B-树的概念4. B-树的插入分析插入过程分析插入过程总结 5. B-树的代码实现5.1 B-树的结点设计5.2 B-树的查找5.3 B-树的插入实现InsertKey插入和分裂测试 6. B-树的删除&#xff08;思想&…