表达式的指针上必须有指针类型错误
Expression must have pointer type error on a pointer?
所以我正在创建一个程序,必须使用2D动态数组来添加/乘/减矩阵。我已经完成了整个程序,但我的析构函数给了我一些问题。当试图释放内存时,我得到错误"表达式必须具有指针类型",即使我认为它已经是指针了?非常感谢您的帮助。
类别:
#ifndef matrixType_H
#define matrixType_H
class matrixType
{
friend std::ostream& operator<<(std::ostream& osObject, const matrixType& cObject);
public:
void setValues(int**, int**, int, int, int, int);
void addMatrices();
void subtractMatrices();
void multiplyMatrices();
void printMatrix();
matrixType operator+(const matrixType& object);
matrixType operator-(const matrixType& object);
matrixType operator*(const matrixType& object);
const matrixType& operator=(const matrixType& object);
matrixType(const matrixType& object);
matrixType();
~matrixType();
private:
int row1;
int row2;
int col1;
int col2;
int **matrixPointer1;
int **matrixPointer2;
};
#endif
根据请求,函数将在从源文件获取用户输入后"设置"我的指针。源文件还包含2个int**指针,我将其复制到类中
void matrixType::setValues(int **matrix1, int **matrix2, int r1, int r2, int c1, int c2)
{
row1 = r1;
row2 = r2;
col1 = c1;
col2 = c2;
matrixPointer1 = matrix1;
matrixPointer2 = matrix2;
}
功能给我问题:
matrixType::~matrixType()
{
for (int i = 0; i < row1; i++){
for (int j = 0; j < col1; j++)
delete[]matrixPointer1[i][j]; //Error: Expression must have pointer type
delete[]matrixPointer1[i];
}
for (int i = 0; i < row2; i++){
for (int j = 0; j < col2; j++)
delete[]matrixPointer2[i][j]; //Error: Expression must have pointer type
delete[]matrixPointer2[i];
}
delete[]matrixPointer1;
delete[]matrixPointer2;
}
由于您还没有提供分配内存的代码,我只能给您一个很好的猜测:
我假设在matrixType
之外的某个地方,你正在做一些事情,效果是:
int** matrix = new int[width];
for (int i = 0; i < width; ++i)
{
matrix[i] = new int[height];
}
在这种情况下,匹配的解除分配将如下所示:
for (int i = 0; i < width; ++i)
{
delete[] matrix[i];
}
delete[] matrix;
请注意,分散matrix
指针的"所有权"是一种不好的做法,以后可能会导致各种问题。随着程序变得越来越复杂,跟踪谁在使用什么内存变得越来越困难,您可能最终会释放一个稍后被取消引用的指针(导致segfault或未定义的行为)。
一个好的经验法则是将内存的所有权保持在创建内存的范围内
例如,如果您有一个分配内存的对象,那么该对象的析构函数应该负责释放它:
// example
class Vector
{
public:
Vector(int size)
{ data = new int[size]; }
~Vector()
{ delete[] data; }
private:
int* data;
};
类似地,如果您在一个函数中分配一些内存,然后将指针传递给另一个函数或范围,则创建函数应该负责释放该内存:
// example
void foo()
{
int* an_array = new int[10];
process_array(an_array);
delete[] an_array; // <-- we allocated in this scope, so we free in this scope
}
相关文章:
- C++中的双指针类型转换
- C++默认情况下,指针类型数组的元素是否保证初始化为 nullptr?
- 将类指针类型转换为键时出错
- 错误:表达式必须具有算术、无作用域枚举或带有运算符重载的指针类型
- C++在一个映射中存储不同的指针类型(并处理销毁)
- 指针类型类成员的动态强制转换的恒定性是什么?
- 我正在尝试将表的地址传递给要在另一个函数中使用的指针,但得到不兼容的指针类型
- 在将派生类指针类型转换为派生类指针后,从基类指针调用派生类函数
- 如何使用静态多态性在 int 和指针类型之间进行转换?
- STL 函数和函数类型与函数指针类型
- 如何调用指针类型的方法(禁用多态性)?
- 为什么新表达式可以正确生成指针类型,即使它应该返回 void*?
- 对于非常量指针类型的参数,未调用具有常量指针模板类型参数的功能
- 是否允许调用方对我的 Builder 类使用任何指针类型(包括智能指针)?
- OPENCL 警告:不兼容的指针类型将'float __global[16]'传递给类型为 '__global float4 的参数 *
- 专门用于"direct"函数类型(与函数指针类型相对)
- 指向成员的指针类型和模板
- 返回对常量结构(指针类型)成员的引用:明显的左值到右值转换
- 在C++17中,为什么类模板和函数模板的指针类型推导明显不一致
- 为什么允许将整型、枚举和指向成员的指针类型reinterpret_cast到自身?