|
使用 malloc 来申请内存,申请的代码部分如下:
float *fp = (float*)malloc(sizeof(float)* h * w);
float **cost = (float**)malloc(sizeof(float*)* h);
for (int i = 0; i < h; ++i) {
cost[i] = &fp[i * w];
}
那我释放的时候应该如何释放呢?
for (int i = 0; i < h; ++i) {
free(cost[i]);
cost[i] = NULL;
}
free(fp);
显然,这个代码在循环的时候就报错了。 |
|
|
应该是先释放一级指针,再释放二级指针吧?
|
|
|
10分 |
有几次malloc就使用几次free;而且二者的地址必须相同;
malloc分配的内存,是有簿记的;只能在分配的地址上释放;否则没法找到大小信息(free用来释放); 所以,不能够“free(cost[i]);”; |
|
10分 |
free (fp); free (cost); 或者 free (*cost); free (cost); 也就是free的次数必须和malloc的次数相同。虽然你分配内存时在for循环中的行为很奇怪(通常二重指针不是这么申请内存的)。 |
|
这样释放的时候不就是一个语句就行了嘛~ |
|
|
20分 |
仅供参考:
#include <stdio.h>
#include <stdlib.h>
#include <malloc.h>
int **newarr2d(int rows,int cols) {
int **p,i;
p=(int **)malloc(rows*sizeof(int *));
if (NULL==p) exit(1);
for (i=0;i<rows;i++) {
p[i]=(int *)malloc(cols*sizeof(int));
if (NULL==p[i]) exit(1);
}
return p;
}
void deletearr2d(int **p,int rows) {
int i;
for (i=0;i<rows;i++) {
free(p[i]);
}
free(p);
}
int main() {
int **arr2d,i,j,r,c;
r=4;
c=5;
//在堆中开辟一个4×5的二维int数组
arr2d=newarr2d(r,c);
for (i=0;i<r;i++) {
for (j=0;j<c;j++) {
arr2d[i][j]=i*c+j;
}
}
for (i=0;i<r;i++) {
for (j=0;j<c;j++) {
printf(" %2d",arr2d[i][j]);
}
printf("\n");
}
deletearr2d(arr2d,r);
r=6;
c=3;
//在堆中开辟一个6×3的二维int数组
arr2d=newarr2d(r,c);
for (i=0;i<r;i++) {
for (j=0;j<c;j++) {
arr2d[i][j]=i*c+j;
}
}
for (i=0;i<r;i++) {
for (j=0;j<c;j++) {
printf(" %2d",arr2d[i][j]);
}
printf("\n");
}
deletearr2d(arr2d,r);
return 0;
}
// 0 1 2 3 4
// 5 6 7 8 9
// 10 11 12 13 14
// 15 16 17 18 19
// 0 1 2
// 3 4 5
// 6 7 8
// 9 10 11
// 12 13 14
// 15 16 17
//
|
|
感谢赵老师~ |
|
|
我那种申请方式有没有问题?因为在 free 的时候,如果按照您这样的,得有一个循环,而按照我写的那种,不需要循环,可能效率会高点?
|
|
|
free(cost);
free(fp); |
|