C++ 浅拷贝 & 深拷贝

举报
我是小白呀iamarookie 发表于 2021/09/09 23:10:54 2021/09/09
【摘要】 C++ 浅拷贝 & 深拷贝 概述对象的赋值对象的复制对象复制的用途建立一个新对象函数的参数为类对象函数的返回值为类对象 浅拷贝深拷贝 概述 浅拷贝 (shallow copy)...

概述

浅拷贝 (shallow copy) 只是对指针的拷贝, 拷贝够两个指针指向同一个内存空间. 深拷贝 (deep copy) 不但对指针进行拷贝, 而且对指针指向的内容进行拷贝. 经过深拷贝后的指针是指向两个不同地址的指针.
在这里插入图片描述

对象的赋值

同类对象之间可以相互赋值. 对象赋值的一般形式:

对象名1 = 对象名2;

  
 
  • 1

举个栗子:

int main() {

    Time t1(6,6,6);
    Time t2 = t1; // 对象赋值
    
    return 0;
}

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

实现原理: 赋值运算符的重载.

对象的复制

对象的复制即用已有的对象克隆出一个新对象. 对象复制的一般格式:

类名 对象2(对象1);

  
 
  • 1

举个栗子:

int main() {

    Time t1(8, 8, 8);
    Time t2(t1);  // 对象的复制
    
    return 0;
}

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
int main() {

    Time t1(8, 8, 8);
    Time t2 = t1;  // 对象的复制
    
    return 0;
}

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

原理: 编译系统默认提供的默认复制构造函数. 如:

Time::Time(const Time& t){
    hour = t.hour;
    minute = t.minute;
    second = t.second;
}

  
 
  • 1
  • 2
  • 3
  • 4
  • 5

对象复制的用途

建立一个新对象

我们可以利用复制构造函数进行初始化而建立一个新对象.

Time t2(t1);

  
 
  • 1

函数的参数为类对象

通过调用复制的构造函数来建立一个实参的拷贝, 在调用函数时我们可以将实参对象完整的传递给形参. 例如:

void fun(Time time);

using namespace std;

int main() {

    Time t1(8, 8, 8);
    fun(t1);

    return 0;
}

void fun(Time time) {
    cout << "function" << endl;
}

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15

函数的返回值为类对象

当函数调用完毕, 我们需要通过调用复制的构造函数将函数中的对象复制一个临时的对象并返回. 例如:

Time fun();

using namespace std;

int main() {

    Time t2;
    t2 = fun();

    return 0;
}

Time fun() {
    Time t1(8, 8,8);
    return t1;
}

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16

浅拷贝

浅拷贝 (Shallow Copy) 只复制某个对象的指针, 而不复制对象本身, 新旧对象还是共享同一块内存.
在这里插入图片描述

Test 类:

#ifndef PROJECT2_TEST_H
#define PROJECT2_TEST_H

class Test {
public:
    int x;
    Test(int n);
    void show();
};

#endif //PROJECT2_TEST_H

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

Test.cpp:

#include <iostream>
#include "Test.h"
using namespace std;

Test::Test(int n) : x(n){}

void Test::show() {
    cout << x << endl;
}

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

main:

#include "Test.h"
#include <iostream>

using namespace std;

int main() {

    Test *pt1 = new Test(100);
    Test *pt2 = pt1;

    pt1 -> x = 5;

    pt1 -> show();
    pt2 -> show();
	
	delete pt1;
	delete pt2;
	
    return 0;
}

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20

输出结果:

5
5

  
 
  • 1
  • 2

深拷贝

深拷贝 (Deep Copy) 在拷贝的过程中会另外创造一个一模一样的对象. 新对象跟原对象不共享内存, 修改新对象不会改到原对象. 例如:

#include "Test.h"
#include <iostream>

using namespace std;


int main() {

    Test a(100);
    Test b = a;

    a.x = 5;
    a.show();
    b.show();

    return 0;
}

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17

输出结果:

5
100

  
 
  • 1
  • 2

文章来源: iamarookie.blog.csdn.net,作者:我是小白呀,版权归原作者所有,如需转载,请联系作者。

原文链接:iamarookie.blog.csdn.net/article/details/116469219

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。