【发布时间】:2017-05-19 02:13:44
【问题描述】:
我的项目中有以下代码:
static int* simpleRoute (int* initialRoute, int n, int i, int k) {
int* newRoute = (int*)malloc(n);
if (!newRoute) {
return NULL;
}
for (int j = 0; j < i; j++) {
newRoute[j] = initialRoute[j];
}
for (int j = i; j < k+1; j++) {
newRoute[j] = initialRoute[j];
}
for (int j = k+1; j < n; j++) {
newRoute[j] = initialRoute[j];
}
return newRoute;
}
我一直有这个错误:
0 0x7ffff7a43428 __GI_raise(sig=sig@entry=6) (../sysdeps/unix/sysv/linux/raise.c:54)
1 0x7ffff7a4502a __GI_abort() (abort.c:89)
2 0x7ffff7a857ea __libc_message(do_abort=2, fmt=fmt@entry=0x7ffff7b9e2e0 "*** Error in `%s': %s: 0x%s ***\n") (../sysdeps/posix/libc_fatal.c:175)
3 ?? 0x00007ffff7a8f81e in malloc_printerr (ar_ptr=0x7ffff7dd1b20 <main_arena>, ptr=0x609370, str=0x7ffff7b9b142 "malloc(): memory corruption", action=<optimized out>) (malloc.c:5004)
4 ?? _int_malloc (av=av@entry=0x7ffff7dd1b20 <main_arena>, bytes=bytes@entry=4) (malloc.c:3472)
5 0x7ffff7a915d4 __GI___libc_malloc(bytes=4) (malloc.c:2911)
6 0x40338b simpleRoute(graphe=0x609580, initialRoute=0x609350, i=6, k=1)
7 0x403522 opt2Simple(graphe=0x609580)
8 0x404b60 main()
我不确定是什么导致了这个错误,有什么帮助吗?
【问题讨论】:
-
与问题无关,但我只是进行了一个标签编辑,这与另一个同时编辑代码示例的同时编辑一致(〜同一秒左右)并合并了编辑。我可以确认@Meryem 进行了代码编辑吗?
-
你写的越界 - 你 malloc
n字节,但你写到n整数到空间。一个int占用超过1个字节 -
int* newRoute = (int*)malloc(n);要求n是sizeof (int)的倍数。将其更改为int* newRoute = malloc(n * sizeof (int));并且无需强制转换malloc。 -
什么是
n?它必须是 sizeof(int) 的倍数才能使代码正常工作。如果n应该是最大索引,则代码应该是int *newRoute = malloc(n*sizeof(*newRoute))。 -
valgrind是你有记忆问题的朋友
标签: c malloc dynamic-memory-allocation