我正在使用简单的2D数组,但在我的复制构造函数中我遇到了一个问题。 这是我的代码的摘录:
//default constructor
Matrix::Matrix(int r, int c)
{
rows = r;
cols = c;
mainArray = new int[rows*cols];
array = new int *[rows];
for (int i = 0; i < rows; i++)
array[i] = mainArray + (i*cols);
}
//at member
int& Matrix::at(int i, int j)
{
return array[i][j];
}
//copy constructor
Matrix::Matrix(const Matrix & obj)
{
rows = obj.rows;
cols = obj.cols;
mainArray = new int[rows*cols];
array = new int *[rows];
for (int i = 0; i < rows; i++)
array[i] = mainArray + (i*cols);
}
for (int i = 0; i < obj.rows; i++)
{
for (int j = 0; j < obj.cols; j++)
at(i, j) =obj.at(i,j);//PROBLEM
}
}
当我尝试分配at(i,j)=obj.at(i,j)
时,我得到了这个:
该对象具有与成员函数
据我所知,复制构造函数应该由(const class& obj)
传递。
我该怎么办?
答案 0 :(得分:2)
那是因为您的复制构造函数采用const
参数,而您的方法Matrix::at
不是常量。
我建议你做两个版本的at
方法,一个是const,一个不是:
// Use for assignement
int& Matrix::at(int i, int j)
{
return array[i][j];
}
// Use for reading
int Matrix::at(int i, int j) const
{
return array[i][j];
}
您的编译器应该知道在哪种情况下调用哪一个没有您的帮助,这取决于您是否尝试修改或只是读取您的实例:
Matrix matrix(4, 4);
matrix.at(1, 2) = 42; // Assignement method called
int i = matrix.at(1, 2); // Read method called
答案 1 :(得分:0)
实现两个版本的at
功能,一个const
和一个non-const
。
int& Matrix::at(int i, int j)
{
return array[i][j];
}
int Matrix::at(int i, int j) const
{
return array[i][j];
}