运算符 = 重载
Operator = overloading
假设我有这个:
struct coor
{
int x;
int y;
COORD operator=(coor c)
{
COORD C={c.x,c.y}
return C;
}
}
我需要做:
coor c={0,0};
COORD C=c;
我可以将运算符重载添加到coor
,但是您如何做到这一点以返回左侧?
运算符=
必须为对象本身的成员赋值。返回值的存在只是为了使a = b = c
和类似的事情正常工作。在您的情况下,这是无关紧要的。此外,如果您有A = B
,将使用 A
中定义的=
,如果您有 B = A
,则使用 B
中的=
。您需要在COORD
中编写一个=
,该coor
参数并更新其成员。
并且以下内容不调用运算符=
:
COORD C=c;
它调用匹配的构造函数。
运算符 = 必须返回*this
如下: a=b=c=d
工作,但这是常规
struct coor
{
int x;
int y;
COORD operator=(coor c)
{
COORD C;
C.x = c.x;
C.y = c.y;
return C;
}
}
要重载operator=
以便它将coor
对象分配给COORD
对象,您必须在COORD
struct
中执行此操作:
struct COORD
{
int x;
int y;
COORD& operator=(coor& c)
{
this->x = c.x;
this->y = c.y;
return *this;
}
};
但是,正如其他人提到的,此重载适用于以下分配:
coor c = {0,0};
COORD C;
C = c;
但不适合
coor c = {0,0};
COORD C = c;
因为第二行实际上是对 COORD 构造函数的调用,它将 coor
的对象作为参数。身体可能看起来像这样:
COORD(coor c):x(c.x),y(c.y)
{
}
相关文章:
- 为什么Mat类的两个对象可以在不重载运算符+的情况下添加
- 重载运算符new[]的行为取决于析构函数
- 为什么将值返回函数传递给重载=运算符对运算符函数有效,而对其他运算符无效
- 在 myVector 类中重载运算符 + 时出错
- 为什么常量词在重载运算符中不与 ostream 对象一起使用<<?
- 如何在 cpp 中重载运算符 +=?
- C++ 如何重载 [] 运算符并进行函数调用
- 重载运算符的范围是什么?它是否会影响作为类成员的集合的插入函数?
- 为什么我可以在不重载 "=" 运算符的情况下将一个对象分配给另一个对象?
- 重载运算符有地址吗?
- 如何迭代重载运算符 [] 的类?
- 重载运算符与添加问题
- 模板基类中的重载运算符
- 如何调用用于重载运算符"<<"的 friend 函数?
- 在 C++17 中的命名空间和子命名空间中重载运算符是不明确的
- 重载运算符<<采用谷歌 C++ 风格
- C++ 如何正确重载 + 运算符
- cout (<<) 重载运算符不打印减去的矩阵
- 如何在 c++ 中重载运算符 + 以便能够 whrite c_str = "smth" + c_str;
- 重载运算符*以获取对另一个类的实例的引用