this指针:
在类的每一个成员函数的形参表中都有一个隐含的指针变量this,该指针变量的类型就是成员函数所属类的类型
当程序中调用类的成员函数时,this指针变量被自动初始化为发出函数调用的对象的地址
this的使用:
1、区分成员和非成员
2、一个类的方法需要返回当前对象的引用
QS& set(int n, string name) {
this->n = n;
this->name = name;
return *this;
}
对第二种方法的简单分析:
#include <iostream>
#include<string>
using namespace std;
class QS {
private://如果省去private表示的还是private属性
int n;
string name;
public:
QS() {
this->n = 1;
name = "wang";
cout << "构造函数" << endl;
}
QS& set(int n, string name) {
this->n = n;
this->name = name;
return *this;
}
~QS(){
cout << "析构函数" << endl;
}
QS yyj(QS j)
{
j.n = this->n + 1;
j.name = j.name + "+yyj";
return j;
}
void show() {
//printf("number=%d name=%s\n", this->n, this->name.c_str());将string型name使用c_str()变为字符数组
cout << "number= " << this->n << " name= " << this->name << endl;
}
};
int main()
{
QS s;
s.show();
QS&ppt=s.set(100,"xiaobai");//并没有定义ppt名字的类,只是ppt指向了s,实现了数据的共享和共同编辑
ppt.show();
s.show();
QS s1;
s1.show();
s1 = s.yyj(s1);//此处为临时变量没有构造但是有析构函数
s1.show();
return 0;
}
此处,this->n=n则为这个函数定义的整形变量n赋值给这个对象的私有成员n
this->name=name即这个函数定义的string类型的name赋值给这个对象的私有成员name
运行结果如下:
由
可知定义的QS& set函数里面并没有构造新的类,而是直接把ppt指向了s,实现了数据的共享和共同编辑
而前两个析构函数则为yyj函数调用的时候产生的临时对象,且这些对象不会调用构造函数且可以通过赋值实现拷贝构造函数的调用