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;
}

执行结果如下:

相关推荐
M ? A16 分钟前
你的 Vue 3 响应式状态,VuReact 如何生成 React Hooks 依赖数组?
前端·javascript·vue.js·经验分享·react.js·面试·vureact
FlyWIHTSKY20 分钟前
HTML 中 `<span>` 和 `<div>` 详细对比
前端·html
competes30 分钟前
React.js JavaScript前端技术脚本运行框架。程序员进行研发组项目现场工作落地的一瞬之间适应性恒强说明可塑性强度达到应用架构师的考核标准
前端·javascript·人工智能·react.js·java-ee·ecmascript
2401_8326355832 分钟前
踩坑分享IntelliJ IDEA 打包 Web 项目 WAR 包(含 Tomcat 部署 + 常见问题解决)
前端·tomcat·intellij-idea
Evavava啊36 分钟前
Android WebView 中 React useState 更新失效问题
android·前端·react.js·渲染
恋恋风尘hhh40 分钟前
Web 端请求签名机制分析:以小红书(XiaoHongShu)x-s 参数为例
前端
包子源41 分钟前
React-PDF 与 Web 预览「像素级」对齐实践
前端·react.js·pdf
Rust研习社1 小时前
Rust Default 特征详解:轻松实现类型默认值
开发语言·后端·rust
jiayong231 小时前
第 25 课:给学习笔记页加上搜索、标签筛选和 URL 同步
开发语言·前端·javascript·vue.js·学习
UXbot1 小时前
如何用 AI 快速生成完整的移动端 UI 界面:从描述到交付的实操教程
前端·ui·交互·ai编程·原型模式