我分配了一個2d數組,並使用memset用零填充。儘管存在memset,但「使用未初始化的值」
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
void main() {
int m=10;
int n =10;
int **array_2d;
array_2d = (int**) malloc(m*sizeof(int*));
if(array_2d==NULL) {
printf("\n Could not malloc 2d array \n");
exit(1);
}
for(int i=0;i<m;i++) {
((array_2d)[i])=malloc(n*sizeof(int));
memset(((array_2d)[i]),0,sizeof(n*sizeof(int)));
}
for(int i=0; i<10;i++){
for(int j=0; j<10;j++){
printf("(%i,%i)=",i,j);
fflush(stdout);
printf("%i ", array_2d[i][j]);
}
printf("\n");
}
}
之後我用valgrind [1]檢查內存錯誤。我得到以下錯誤:行24(printf("%i ", array_2d[i][j]);
)Conditional jump or move depends on uninitialised value(s)
。我一直認爲memset是初始化數組的函數。我怎樣才能擺脫這個錯誤?
謝謝!
Valgrind的輸出:
==3485== Memcheck, a memory error detector
==3485== Copyright (C) 2002-2009, and GNU GPL'd, by Julian Seward et al.
==3485== Using Valgrind-3.5.0-Debian and LibVEX; rerun with -h for copyright info
==3485== Command: ./a.out
==3485==
(0,0)=0 (0,1)===3485== Use of uninitialised value of size 4
==3485== at 0x409E186: _itoa_word (_itoa.c:195)
==3485== by 0x40A1AD1: vfprintf (vfprintf.c:1613)
==3485== by 0x40A8FFF: printf (printf.c:35)
==3485== by 0x8048724: main (playing_with_valgrind.c:39)
==3485==
==3485==
==3485== ---- Attach to debugger ? --- [Return/N/n/Y/y/C/c] ----
==3485== Conditional jump or move depends on uninitialised value(s)
==3485== at 0x409E18E: _itoa_word (_itoa.c:195)
==3485== by 0x40A1AD1: vfprintf (vfprintf.c:1613)
==3485== by 0x40A8FFF: printf (printf.c:35)
==3485== by 0x8048724: main (playing_with_valgrind.c:39)
[1] valgrind --tool=memcheck --leak-check=yes --show-reachable=yes --num-callers=20 --track-fds=yes --db-attach=yes ./a.out
[GCC-CMD] gcc -std=c99 -lm -Wall -g3 playing_with_valgrind.c
確實好眼睛! – 2010-06-14 13:41:03
啊!非常感謝你。我會盡快接受你的回答。 – Framester 2010-06-14 13:41:26
斑點......很難看 – Spudd86 2010-06-15 18:32:45