我使用malloc时遇到问题。
我有一个名为jacobi_gpu
的函数,它被多次调用:
int main(int argc, char* argv[]){
/* ... */
int totalrot=0;
while(nrot>0){
iter++;
nrot=jacobi_gpu(a,q, tol, dimmat);
totalrot+=nrot;
printf("iter =%3d nrot=%3d\n",iter, nrot);
}
/* ... */
}
正确初始化参数a,q,tol和dimmat。 A和Q是2平方矩阵,dimmat是它们的维度。
这是我的代码:
int jacobi_gpu(double A[], double Q[], double tol, long int dim){
int nrot, p, q, k, tid;
double c, s;
double *mc, *vc;
printf("jacobi begins \n");
mc = (double *)malloc(2 * dim * sizeof(double));
vc = (double *)malloc(2 * dim * sizeof(double));
if( mc == NULL || vc == NULL){
fprintf(stderr, "pb allocation matricre\n");
exit(1);
}
nrot = 0;
for(k = 0; k < dim - 1; k++){
eye(mc, dim);
eye(vc, dim);
for(tid = 0; tid < floor(dim /2); tid++){
p = (tid + k)%(dim - 1);
if(tid != 0)
q = (dim - tid + k - 1)%(dim - 1);
else
q = dim - 1;
//printf("p = %d | q = %d\n", p, q);
if(fabs(A[p + q*dim]) > tol){
nrot++;
symschur2(A, dim, p, q, &c, &s);
mc[2*tid] = p; vc[2 * tid] = c;
mc[2*tid + 1] = q; vc[2*tid + 1] = -s;
mc[2*tid + 2*(dim - 2*tid) - 2] = p;
vc[2*tid + 2*(dim - 2*tid) - 2 ] = s;
mc[2*tid + 2*(dim - 2*tid) - 1] = q;
vc[2 * tid + 2*(dim - 2*tid) - 1 ] = c;
}
}
affiche(mc,dim,2,"Matrice creuse");
affiche(vc,dim,2,"Valeur creuse");
}
printf("end\n");
free(mc);
free(vc);
return nrot;
}
我的问题是在mc变量的malloc调用中:
*** glibc detected *** ./jacobi_gpu: double free or corruption (!prev): 0x00000000022944a0 ***
*** glibc detected *** ./jacobi_gpu: malloc(): memory corruption: 0x0000000002294580 ***
有什么建议吗?
[编辑]
矩阵mc的目的是存储变量p和q。这些变量包含列索引。 矩阵vc的目的是存储这些列中包含的值。 例如,如果矩阵mc的第一行是0和5(p = 0,q = 5),则意味着矩阵vc中的值将在列0和5中。 如果矩阵mc中的矩阵第五行是2 3(p = 2,q = 3),则意味着vc中第五行中的值将在第2列和第3列中。
希望这次,我更清楚。
感谢您的帮助
答案 0 :(得分:6)
答案 1 :(得分:2)
在调用malloc()
时,您没有为方阵分配足够的内存。正确的大小为dim
平方,而不仅仅是2*dim
。
这应该可以解决问题:
mc = (double *)malloc(dim * dim * sizeof(double));
vc = (double *)malloc(dim * dim * sizeof(double));
答案 2 :(得分:0)
答案 3 :(得分:0)