开发者社区> 问答> 正文

析构函数中使用delete报错 ?报错

把析构函数里的delete去掉就不会报错了;但是搞不懂:我的构造函数里不是用了new吗,为什么会出现这种情况?
报错信息是:_BLOCK_TYPE_IS_VALID(pHead->nBlockUse),网上查了一下都说是重发调用delete的结果,但是我好像没有那么做。

//Matrix.h
class Matrix
{
public:
Matrix();
~Matrix();
Matrix(int,double*); //矩阵行列数、数组指针
Matrix operator+(const Matrix&);//矩阵相加
friend ostream& operator<<(ostream&,const Matrix&);//
private:
int n; //矩阵的行列数
double* pt;
};

//Matrix.cpp
Matrix::Matrix():pt(0)
{
n = 0;
}
Matrix::Matrix(int r,double* p): n(r)
{

pt = new double[r*r];
for(int i=0; i<r*r;i++)

pt[i] = p[i];

}
Matrix::~Matrix()
{
delete []pt;
pt = 0;
}
//矩阵相加函数实现
Matrix Matrix::operator+(const Matrix& m)
{
for(int i=0;i<n*n;i++)

pt[i] = pt[i] + m.pt[i];

return *this;
}
//矩阵输出函数的实现
ostream& operator<<(ostream& output,const Matrix& m)
{

for(int i=0;i<m.n*m.n;i++)

{

if((i+1)%m.n == 0)

output<<m.pt[i]<<endl;

else

output<<m.pt[i]<<" ";

}

return output;

}

然后就是main函数中
double *p1,*p2,x,y;
int n;

cout<<"请输两个矩阵的行列数(n*n):"<<endl<<"n=";
cin>>n;

cout<<"请输入第一个矩阵m1的元素:"<<endl;

p1=(double *)malloc(sizeof(double)*n*n);
for(int i=0;i<n*n;i++)      
{       
    cin>>x;     
    p1[i]=x;    
}

cout<<"请输入第二个矩阵m2的元素:"<<endl;
p2=(double*)malloc(n*n*sizeof(double));
for(int j=0;j<n*n;j++)  
{   
    cin>>y; 
    p2[j]=y;    
}   

Matrix m1(n,p1),m2(n,p2),M;
M=m1+m2;    
cout<<"m1+m2:"<<endl;   
cout<<M<<endl;
free(p1);
free(p2);
return 0;

展开
收起
爱吃鱼的程序员 2020-06-23 15:01:45 595 0
1 条回答
写回答
取消 提交回答
  • https://developer.aliyun.com/profile/5yerqm5bn5yqg?spm=a2c6h.12873639.0.0.6eae304abcjaIB

    缺少拷贝构造函数,对象引用时,拷贝构造出新的对象,而pt指向的申请空间都是同一片,最终你释放了两次,那么第二次必然就野了

    delete[]pt;换成deletept;试试。
    因为pt不是一个数组、

    2020-06-23 15:02:04
    赞同 展开评论 打赏
问答分类:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载