使用malloc()/ calloc()创建内存的错误概念
我对malloc()/ calloc()创建内存的方式的概念一直是创建一个项目后,对象的地址保持不变.但是我经常用来创建一个字符串数组的函数,以及一个似乎一直运行良好的函数,最近让我质疑我的理解,也就是说,只需调用calloc /就可以(并且)移动对象的内存地址malloc的.
为了说明,这里是我用来为字符串数组创建内存的函数 – char **: char ** CreateArrayOfStrings(char **a,int numWords,int maxWordLen) { int i; a = calloc(numWords,sizeof(char *)); //create array of pointers if(!a) return a; //required caller to check for NULL for(i=0;i<numWords;i++) { a[i] = calloc(maxWordLen + 1,1); //create memory for each string } return a; } 在我的系统上,(Win7,32bit编译,ANSI C)该行: a = calloc(numWords,sizeof(char *)); //create array of pointers 创建一个连续内存块,大小为numWords char *,在本例中为7,产生28个字节: ?? 内存跨度从地址0x03260080 1C(0x0326009C) a[0] is at 0x3200260080 a[1] is at 0x3200260084 a[2] is at 0x3200260088 a[3] is at 0x320026008C a[4] is at 0x3200260090 a[5] is at 0x3200260094 a[6] is at 0x3200260098 然后,我为每个numWords(7)字符串创建内存 for(i=0;i<numWords;i++) { a[i] = calloc(maxWordLen + 1,1); //maxWordLen == 5 in this example } 其结果如下: ?? 这表明指针a [1] – a [6]的存储位置已经改变. 有人可以解释在malloc()/ calloc()中如何/为什么会这样? 解决方法
您似乎正在将苹果与橙子进行比较:
>当您打印[i]是…指针时,您将显示数组a中元素的地址 如果在为其分配calloc结果之前在[i]处打印值,则应该全部为零,因为calloc将内存空出来.在分配之后,您会看到每个a [i]处指向6字节块的指针,这非常有意义. 总而言之,您对使用malloc和calloc分配内存时所发生的事情的初步了解是正确的:一旦分配了一块内存,其地址*保持不变. *在具有虚拟内存的系统上,我应该说“它的虚拟地址”. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |