【发布时间】:2014-10-21 13:07:43
【问题描述】:
我正在使用归并排序编写一个简单的计数反转程序。在运行时使用 calloc 分配内存时出现以下错误:
a.out: malloc.c:2372: sysmalloc: Assertion `(old_top == (((mbinptr) (((char *) &((av)->bins[((1) - 1) * 2])) - __builtin_offsetof (struct malloc_chunk, fd)))) && old_size == 0) || ((unsigned long) (old_size) >= (unsigned long)((((__builtin_offsetof (struct malloc_chunk, fd_nextsize))+((2 *(sizeof(size_t))) - 1)) & ~((2 *(sizeof(size_t))) - 1))) && ((old_top)->size & 0x1) && ((unsigned long) old_end & pagemask) == 0)' failed.
Aborted (core dumped)
使用此代码:
int *temp = (int*)calloc(1, sizeof(int) * (l1+l2)) ;
虽然使用 malloc 而不是 calloc 可以正常工作。在谷歌搜索时,我发现这是一种内存损坏问题,但没有弄清楚
【问题讨论】:
-
工作正常意味着您可以有效地使用
temp? -
在 C++ 中不要使用
calloc,在 C 中不要使用 don't cast the return。 -
关于您遇到的问题,因为您分配了零字节,
malloc和calloc都允许返回NULL或有效指针(它的实现已定义)。如果你得到一个非空指针,所有对你“分配”的内存的写入都将超出范围,导致undefined behavior。 -
很抱歉是 1 而不是 0
-
将
calloc(0, sizeof(int) * (l1+l2))更改为calloc(1, sizeof(int) * (l1+l2))极大地改变了问题——不是吗?为什么你在通话中做乘法而不是让calloc()为你做?不过,这是一个小问题。鉴于修改后的编码,您在某处践踏了界限。主要区别在于calloc()将内存归零malloc()不会。您可能会遇到将零点作为空指针并且工作方式不同的代码。valgrind是否适用于您的平台?如果是这样,请使用它。如果没有,请获取虚拟机。
标签: c++ c memory-management malloc calloc