我想在一个函数调用中创建一个连续的内存块,该函数调用将第一部分内存作为指针数组指向其他块。基本上,我试图做到:与malloc连续内存块
int **CreateInt2D(size_t rows, size_t cols)
{
int **p, **p1, **end;
p = (int **)SafeMalloc(rows * sizeof(int *));
cols *= sizeof(int);
for (end = p + rows, p1 = p; p1 < end; ++p1)
*p1 = (int *)SafeMalloc(cols);
return(p);
}
void *SafeMalloc(size_t size)
{
void *vp;
if ((vp = malloc(size)) == NULL) {
fputs("Out of mem", stderr);
exit(EXIT_FAILURE);
}
return(vp);
}
但有一个块。这是据我已经得到了:
int *Create2D(size_t rows, size_t cols) {
int **memBlock;
int **arrayPtr;
int loopCount;
memBlock = (int **)malloc(rows * sizeof(int *) + rows * cols * sizeof(int));
if (arrayPtr == NULL) {
printf("Failed to allocate space, exiting...");
exit(EXIT_FAILURE);
}
for (loopCount = 1; loopCount <= (int)rows; loopCount++) {
arrayPtr = memBlock + (loopCount * sizeof(int *));
//I don't think this part is right. do I need something like arrayPtr[loopCount] = ....
}
return(memBlock);
}
我想我得到你的答案,但我在为行指针和列分配内存的想法有问题。因此,对于那块内存,cb,你可以只是将pmem部分分类来分割它?像第一部分是指向指针的指针,然后指向最后一行指针的pcol,然后初始化cols并让指针指向的指针指向pcol?像那样的东西? – Crystal 2010-02-12 09:50:32
是的。你分配总数,然后使用指针数学得到一个pcol指针,指向第一个地址_after_你想要分配给prows的部分,然后遍历pcol指针并使用它来初始化prow数组。最终的结果是一个分配,但与原始代码具有相同的布局。 – 2010-02-12 09:55:21
@Crystal:再次检查代码,我有一个循环中的错误。抱歉。 – 2010-02-12 10:01:07