[英]Memory Leak with valgrind
这也许最终是一个愚蠢的问题。 我已经完成了以下功能:
char **getArrayOfStrings(int rows, int cols){
int i;
char **aux = malloc(rows * sizeof(char*));
for(i = 0; i < rows; i++)
aux[i] = malloc(cols+1);
return aux;
}
这将返回一个“字符串”数组,重要的代码块类似于:
void f(...)
{
char **arrayOfStrings;
int i = 0;
arrayOfStrings = getArrayOfStrings(ROWS,COLS);
while(ch != '.' && sscanf (globalString,"%[^,|.]s", arrayOfStrings[i]) > 0)
{
globalString += strlen(arrayOfStrings[i++]) + 1;
ch = (*globalString-1); /** take the terminal characters */
}
freeMemory(&arrayOfStrings,ROWS);
}
freeMemory在哪里:
void freeMemory(char ***matrix, int size){
int i;
for(i = 0; i < size; i++) free((*matrix)[i]);
free(*matrix);
*matrix = NULL;
}
完成我的应用程序后,我使用valgrind运行以查找内存泄漏(第一次使用valgrind)。
我得到以下错误:
Finding Invalid Pointer Use With Valgrind
==25012== Copyright (C) 2002-2011, and GNU GPL'd, by Julian Seward et al.
==25012== Using Valgrind-3.7.0 and LibVEX; rerun with -h for copyright info
==25012== Command: dist/Debug/GNU-MacOSX/app
==25012==
==25012== Invalid read of size 8
==25012== at 0x406445: f (Data.c:24)
==25012== by 0x400BE3: main (main.c:27)
我不知道我缺少什么,因为函数getArrayOfStrings对我来说似乎非常好(我本可以只使用一个malloc,但这是另一个问题)。
编辑 。
valgrind指示的行是此f(Data.c:24):
char **aux = malloc(rows * sizeof(char*));
以我对valgrind的经验来看,它确实表明非法访问已完成。 但是,您的输出似乎仅显示与非法访问有关的指针及其分配位置。
这意味着我们可能看错了代码行。
仔细查看您的while循环:
while(ch != '.' && sscanf (globalString,"%[^,|.]s", arrayOfStrings[i]) > 0)
{
globalString += strlen(arrayOfStrings[i++]) + 1;
ch = (*globalString-1); /** take the terminal characters */
}
如果由于某种原因,在最后一行ch
不等于.
非法访问将在arrayOfStrings[rows]
。 分配行+1是一种解决方法。 内容未知,没有几率.
在那里,将while条件评估为false且没有非法访问。
我建议要么确保.
出现在最终迭代中,或者在您的while条件中包含诸如i < ROWS
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.