运算符重载说明

Operator overloading explanation

本文关键字:说明 重载 运算符      更新时间:2023-10-16

我正在尝试理解使用运算符重载的短程序的输出。

输出为 137,其中(2+v).print()输出137来自v.print();

#include <iostream>
using namespace std;
class V
{
int x;
public:
V(int a = 7, int b = 3) { x = a + b; }
void print() { cout << x; }
V operator+(int n)
{
return x++ + ++n;
}
};
V operator+(int lop, V rop)
{
return rop + lop;
}
int main()
{
V v(1, 6);
(2 + v).print();
v.print();
return 0;
}

我了解运算符重载的基本概念,我得到V rop只是V v(1,6)的副本,它不会改变x保持 7 的v.print();的输出,但我不明白为什么它输出 13,我总是得到 10。

问题是当尝试从此运算符返回类型为"V"的对象时:

V operator+(int n)
{
return x++ + ++n;
}

您尝试在"int"中返回的内容,因此它应该强制转换为类型"V"的对象,其完成方式(从基元类型转换为自定义类(是使用构造函数。您拥有的唯一构造函数是具有 2 个可选参数,这会产生它尝试仅创建一个参数的对象的问题,因此它以 a = 10、b = 3(默认值(的形式发送,然后输出为 13。

如果您不想更改类的成员,我建议使用多个构造函数来解决问题。

class V
{
int x;
public:
V() { x = 10; }
V(int a) { x = a; }
V(int a, int b) { x = a + b; }
void print() { cout << x; }
V operator+(int n)
{
return x++ + ++n;
}
};

通过这种方式,您可以调用一个默认构造函数,该构造函数像以前一样将 x 设置为 10,另一个具有 1 个参数的构造函数从 'int' 转换为 'V',以及采用 a 和 b 的普通构造函数。

在到达编译器return (x++ + ++n);code创建一个对象V以便再次调用构造函数。 然后这些分配将发生a=10b=3.所以你必须保存a并在另一个membersb值。

试试这个:

#include <iostream>
using namespace std;
class V {
int x;
int a;
int b;
public:
V(int a=7, int b=3) { x = a + b; this->a = a; this->b = b; }
void print() { cout << x - this->b; }
V operator+(int n) {
return (x++ + ++n);
}
};
V operator+(int lop, V rop) {
return rop + lop;
}
int main()
{
V v(1,6);
(2 + v).print();
v.print();
return 0;
}

您的(2 + v).print();输出将10