时间:2021-05-19
首先c++里的各种运算符都是用函数实现的,比如=,就等号函数。
所以当用=给一个对象赋值的时候,实际调用的是=号所对应的=号函数。
分析下面的代码
#include <iostream>using namespace std;class Test{public: explicit Test(){ data = 0; } explicit Test(int d):data(d){ cout << "C:" << this << ":"<< this->data << endl; } //拷贝构造函数 Test(const Test &t){ cout << "Copy:" << this << endl; data = t.data; } //重载=号运算符 Test& operator= (const Test &t){ cout << "assign" << this << endl; if(this != &t){ data = t.data; } return *this; } ~Test(){ cout << "F:" << this << ":" << this->data << endl; }private: int data;};int main(){ Test t1(10); Test t2, t3; t3 = t2 = t1; return 0;}重点分析下面的函数
//重载=号运算符 Test& operator = (const Test &t){ cout << "assign" << this << endl; if(this != &t){ data = t.data; } return *this; }分析点:
1,operator =是什么意思
2,参数为什么是引用类型
3,参数为什么有const限制
4,为什么有if(this != &t)的判断
5,为什么有返回值
6,为什么返回值的类型是引用类型
分析点解答:
Test t2;
t2 = t1;//实际的运作方式是t2.operator=(t1),所以函数里面的this就是t2
1,重载类Test的=号函数,当对类Test的对象用=号操作的时候,就会调用这个重载后的函数
2,避免调用拷贝构造函数
3,避免不小心修改里参数t里面成员变量的值(t.data = 100;)
4,防止自己给自己赋值
5,为了能够使用 t3 = t2 = t1。如果没有返回值,则t3.operator=(t2=t1),的参数里面t2=t1就没有返回值,所以编译不过。
6,不是引用也可以,用引用类型是防止老版本的编译器,在return处调用拷贝构造函数,新版本的编译器(gcc 4.8.5-20),即使不用引用类型,就不会调用拷贝构造函数。
总结
以上所述是小编给大家介绍的c/c++赋值函数(重载=号运算符),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
C++规定有四个运算符=,->,[],()不可以是全局域中的重载(即不能重载为友员函数),这是为什么呢?现在先说说赋值运算符“=”的重载C++规定赋值运算符“=
C++单目运算符重载单目运算符只有一个操作数,如!a,-b,&c,*p,还有最常用的++i和--i等。重载单目运算符的方法与重载双目运算符的方法是类似的。但由于
C++赋值语句讲解C++的赋值语句具有其他高级语言的赋值语句的功能。但不同的是,C++中的赋值号“=“是一个运算符,可以写成a=b=c=d;而在其他大多数语言中
C++允许在同一作用域中的某个函数和运算符指定多个定义,分别称为函数重载和运算符重载。重载声明是指一个与之前已经在该作用域内声明过的函数或方法具有相同名称的声明
operator是C++的关键字,它和运算符一起使用,表示一个运算符函数,理解时应将operator=整体上视为一个函数名。这是C++扩展运算符功能的方法,虽然