在一个命令中使用 2 个重载运算符会导致错误

Using 2 overloaded operators in one command cause an error

本文关键字:运算符 重载 错误 一个 命令      更新时间:2023-10-16

>我在C++中创建了一个带有重载运算符的矩阵类,我重载了运算符,<<(输出,带有 ostream 库(,运算符 + 添加到矩阵中,运算符 = 用于将一个矩阵分配给另一个矩阵。问题是当我使用

cout<<m1+m2<<endl;

我收到错误

E0349: No operator << matches these operands type are: std::ostream << Matrix

但是如果我执行以下操作:

Matrix m = m1 + m2;
cout<<m<<endl;

它工作完美。 这是<<运算符:

ostream& operator<< (ostream &os,const Matrix& m)
{
if (m.isValid())
{
os << '|';
for (int i = 0; i < m.getRows(); i++)
{
for (int j = 0; j < m.getCols(); j++)
{
os << m.getMatrix()[i][j];
if (j < m.getCols() - 1)
{
os << ',';
}
}
os << '|';
}
}
else
{
os << "invalid matrix!";
}
return os;
}

+ 运算符:

Matrix Matrix::operator+ (Matrix &m)
{
Matrix* answer = new Matrix(m); //allocating space
if (valid && m.valid)//if they are both valid
{
if (colNum == m.colNum&&rowNum == m.rowNum) //if are from same size
{
answer->valid = true; //valid set to be true
for (int i = 0; i < rowNum; i++) //going over the matrix
{
for (int j = 0; j < colNum; j++)
{
answer->matrix[i][j] += matrix[i][j]; //adding data
}
}
}
else
{
//clearing data
delete answer;
answer = new Matrix();
}
}
else
{
//clearing data
delete answer;
answer = new Matrix();
}
return *answer;
}

和 = 运算符:

Matrix Matrix::operator= (Matrix &m)
{
int rows = m.rowNum; //putting cols and rows from the data
int cols = m.colNum;
if (m.valid)
{
matrix = new int*[rows]; //defining the matrix - first allocatin space for rows
for (int i = 0; i < rows; i++) //now allocating space for cols
{
matrix[i] = new int[cols];
}
for (int i = 0; i < rows; i++) //now going over the matrix and putting the data in
{
for (int j = 0; j < cols; j++)
{
matrix[i][j] = m.matrix[i][j];
}
}
}
//putting the rows and cols data
rowNum = m.rowNum;
colNum = m.colNum;
valid = m.valid; //setting to the right valid type
return *this;
}

和类变量:

class Matrix
{
private:
bool valid;
int** matrix;
int rowNum;
int colNum;

有一个复制构造函数、字符串构造函数和一个根据算法获取字符串输入并将其转换为矩阵的构造函数。

您实际上面临着无法传递临时对象作为引用的事实(链接指向 StackOverflow 上的另一个问题(。

在您的情况下,解决方案应该是替换:

ostream& operator<< (ostream &os,Matrix& m)

跟:

ostream& operator<< (ostream &os,const Matrix& m)

作为重载的运算符签名。您当前期望一个左值引用,在

Matrix m = m1 + m2;
cout << m << endl;

这就是你用m调用函数的原因 - 一个命名变量,将在命令的执行之后存活。在失败的情况下,您将使用m1+m2调用函数 - 加号操作的结果,这是一个临时对象。它只是与您的过载不匹配。

顺便说一下 - 这种更改也很有意义,因为您在打印时不会修改矩阵 - 您将其视为const.