*this的一个注意点

*this不能用于静态成员,只能用于非静态成员函数内部
*this指的是类的实例,用的形式为(this).xx或者this->xx
因为
this是实例,所以直接cout<<*this就需要重载输出流运算符,因为输出对象
this是实例的地址,实例的指针
在这里插入图片描述

#include<iostream>

#include<iomanip>

using namespace std;

class CComplex {

private:

 double r, i;

public:

 CComplex(double r = 0, double i = 0) {

 this->r = r;

 this->i = i;

 cout << "Constructor: " << "("<<this->r<<", " <<this->i<<")"<<endl;

 };

 ~CComplex() {

 cout<<"Destructor: "<<"("<< this->r << ", " << this->i << ")" << endl;

 }

 friend CComplex operator+(CComplex c1, CComplex c2);

 friend  ostream& operator <<(ostream& os, const CComplex& CTemp)

 {

 os << "(" << CTemp.r << ", " << CTemp.i << ")";

 

 return os;

 }

};

CComplex operator+(CComplex c1, CComplex c2)

{

 CComplex CTemp;

 CTemp.r = c1.r + c2.r;

 CTemp.i = c1.i + c2.i;

 return CTemp;

}



int main()

{

 double r1, i1;

 double r2, i2;

 cin >> r1 >> i1;

 cin >> r2 >> i2;

 CComplex c1(r1, i1) , c2(r2, i2);

 CComplex c3 = c1 + c2;

 cout << c1 << endl;

 cout << c2 << endl;

 cout << c3 << endl;

}


这里的重载加法运算符用到了友元函数
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
这里出现问题的原因也是this指向静态成员了

重载加法运算符可以这样写,用&,因为这样就可以省略两个参数传过去的过程中调用拷贝构造,并且这个

CComplex CComplex:: operator+(const CComplex& b)
{
	CComplex Temp;
	Temp.r = this->r + b.r;
	Temp.i = this->i + b.i;
	return Temp;
}

在这里插入图片描述
并且这样*this也可以用了

改进后的代码

#include<iostream>

#include<iomanip>

using namespace std;

class CComplex {

private:

	double r, i;

public:

	CComplex(double r = 0, double i = 0) {

		this->r = r;

		this->i = i;

		cout << "Constructor: " << "(" << this->r << ", " << this->i << ")" << endl;
	

	};

	~CComplex() {

		cout << "Destructor: " << "(" << this->r << ", " << this->i << ")" << endl;

	}
	

	CComplex(CComplex& t)
	{
		this->i = t.i;
		this->r = t.r;
		cout << *this << "copy construction" << endl;
	}
	
	CComplex operator+(CComplex& b);
	friend  ostream& operator <<(ostream& os,  CComplex& CTemp)

	{

		os << "(" << CTemp.r << ", " << CTemp.i << ")";



		return os;

	}

};


CComplex CComplex:: operator+( CComplex& b)
{
	CComplex Temp;
	Temp.r = this->r + b.r;
	cout << *this<<endl;
	Temp.i = this->i + b.i;
	cout << *this<<endl;
	return Temp;
}




int main()

{

	double r1, i1;

	double r2, i2;

	cin >> r1 >> i1;

	cin >> r2 >> i2;

	CComplex c1(r1, i1), c2(r2, i2);

	CComplex c3 = c1 + c2;

	cout << c1 << endl;

	cout << c2 << endl;

	cout << c3 << endl;

}

在这里插入图片描述
运行处了两个(1,1),这个点嘛,*this指针指向最后的那一次c1输人,因为加法传参数从右往左传(我也不知道对不对,自己想的,保留疑问吧)

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值