鱼C论坛

 找回密码
 立即注册
查看: 1038|回复: 5

[已解决]形参为什么一定要用引用的形式

[复制链接]
发表于 2020-9-11 21:31:37 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
#include<iostream>

using namespace std;

class Complex
{
public:
        Complex() { real = 0; imag = 0; }
        Complex(double r, double i) { real = r; imag = i; }
        Complex complex_add(Complex& c2);
        void display();
private:
        double real;
        double imag;
};

Complex Complex::complex_add(Complex& c2)
{
        Complex c;
        c.real = real + c2.real;
        c.imag = imag + c2.imag;
        return c;
}

void Complex::display()
{
        cout << "(" << real << "," << imag << "i)" << endl;
}

int main()
{
        Complex c1(3, 4), c2(5, -10), c3;
        c3 = c1.complex_add(c2);

        cout << "c1=";
        c1.display();
        cout << "c2=";
        c2.display();

        cout << "c1+c2=";
        c3.display();

        return 0;
}
这是一个实现复数相加的代码
想问一下各位大神们为什么complex_add函数的形参一定要是引用呢
我尝试了一下直接传值也是可以的
请大神们赐教!
最佳答案
2020-9-11 21:47:47
本帖最后由 livcui 于 2020-9-11 21:53 编辑

1. 省内存
2. 有点难说,反正把类作为形参类型基本就是找死(除非有拷贝构造函数等)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-9-11 21:47:47 | 显示全部楼层    本楼为最佳答案   
本帖最后由 livcui 于 2020-9-11 21:53 编辑

1. 省内存
2. 有点难说,反正把类作为形参类型基本就是找死(除非有拷贝构造函数等)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-9-11 22:47:25 | 显示全部楼层
livcui 发表于 2020-9-11 21:47
1. 省内存
2. 有点难说,反正把类作为形参类型基本就是找死(除非有拷贝构造函数等)
反正把类作为形参类型基本就是找死
这里不会出问题的吧
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-9-12 07:25:57 | 显示全部楼层

我只是说最好...

后面有用到动态内存分配,就gg了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-9-12 08:36:23 | 显示全部楼层
livcui 发表于 2020-9-11 21:47
1. 省内存
2. 有点难说,反正把类作为形参类型基本就是找死(除非有拷贝构造函数等)

好滴,谢谢啦
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-9-12 09:22:49 | 显示全部楼层
  来凑个热闹 。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-13 06:13

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表