c++ 拷贝构造函数

何时需要拷贝函数?

下面我们看一段代码?

c++ 复制代码
#include <iostream>

using namespace std;

class Line
{
  public:
    string m_name;
    int m_age;
    Line();
    ~Line(); // 析构函数
    
    void show();
};
Line:: Line()
{
  cout << "无参构造被调用" << endl;
}
Line:: ~Line()
{
  cout << "析构函数~Line()被调用" << endl;
}
void Line:: show()
{
  cout << "姓名:" << m_name << ",年龄: " << m_age << endl;
}
int main()
{
  Line line1("张三", 18);
  Line line2 = line1;
  
  return 0;
}

这时候编译,会提示你 已经告诉你答案了。

拷贝构造函数的规则

拷贝构造函数是一种特殊的构造函数,它在创建对象时,是使用同一类中之前创建的对象来初始化新创建的对象。

  • 用一个已存在的对象创建新的对象,不会调用(普通)构造函数,而是调用拷贝构造函数。

  • 如果类中没有定义拷贝构造函数,编译器将提供一个拷贝构造函数,它的功能是把已存在对象的成员变量赋值给新的对象的成员变量。

  • 用一个已存在的对象创建新的对象语法:

    • 类名 新对象名(已存在的对象名)

    Line line1("张三", 18);

    Line line2(line1);

    • 类名 新对象名 = 已存在的对象名。

    Line line1("张三", 18);

    Line line2 = line1;

拷贝构造函数的写法

c++ 复制代码
classname (const classname &obj) 
{ 
    // 构造函数的主体 
}

接下来把上面的例子补齐

c++ 复制代码
#include <iostream>

using namespace std;

class Line
{
  public:
    string m_name;
    int m_age;
    Line();
    Line(string name, int age);  // 构造函数
    Line(const Line &obj);
    Line(const Line &obj, int n);
    ~Line(); // 析构函数
    
    void show();
};
Line:: Line()
{
  cout << "无参构造被调用" << endl;
}
Line:: Line(string name, int age)
{
  m_name = name;
  m_age = age;
  cout << "构造函数Line(string name1, int age)被调用" << endl;
}
Line:: Line(const Line &obj)
{
  cout << "拷贝构造函数被调用" << endl;
  cout << "拷贝构造 - 姓名:" << obj.m_name << ",拷贝构造 - 年龄: " << obj.m_age << endl;
  m_name = obj.m_name;
  m_age = obj.m_age;
}
Line:: ~Line()
{
  cout << "析构函数~Line()被调用" << endl;
}

// 实现成员函数
void Line:: show()
{
  cout << "姓名:" << m_name << ",年龄: " << m_age << endl;
}
int main()
{
  Line line1("张三", 18);

  Line line2 = line1;
  line2.show();

  return 0;
}

执行结果如下:

相关推荐
忆江南23 分钟前
HTTP 各版本演进与 HTTPS 原理详解
前端
缓解AI焦虑25 分钟前
大模型量化部署进阶:从 INT8/INT4 原理到高性能推理实战
后端
忆江南25 分钟前
对组件化与模块化的思考与总结
前端
小码哥_常30 分钟前
从0到1:Android组件化架构搭建秘籍
前端
忆江南30 分钟前
iOS 应用启动流程与优化详解
前端
itslife34 分钟前
前端架构模式思考
前端·架构
Felix_One40 分钟前
ESP32 + Qt 串口通信(一):从协议设计到双向数据链路
后端
Wect40 分钟前
JSX & ReactElement 核心解析
前端·react.js·面试
雨落Re40 分钟前
从递归组件到 DSL 引擎:我造了一个让 AI 能"搭 UI"的运行时
前端·vue.js
Maxkim41 分钟前
前端工程化落地指南:pnpm workspace + Monorepo 核心用法与实践
前端·javascript·架构