char **add_string(char **existing, const char *string){
size_t size = 0;
while (NULL != existing[size])
{
++size;
}
char **arr = realloc(existing, (size + 2) * sizeof *arr);
arr[size] = malloc(strlen(string) + 1);
strcpy(arr[size], string);
arr[size+1] = '\0';
return arr;
}
void free_strings(char **strings)
{
size_t size = 0;
while (NULL != strings[size])
{
free(strings[size]);
++size;
}
}
我在第
行有内存泄漏char **arr = realloc(existing, (size + 2) * sizeof *arr);
我认为在使用realloc时,现有内存被认为是免费的?如何修复此内存泄漏?
编辑:添加了我的free_string函数和我用来运行程序的主要文件。
答案 0 :(得分:1)
您没有使用空指针附加指针existing
指向的数组。因此在这个循环中
while(NULL!=现有[size]) { ++大小; }
该函数具有未定义的行为。
看来你的意思是以下
char ** add_string( char **existing, const char *string )
{
size_t size = 0;
while ( NULL != existing[size] ) ++size;
char **arr = realloc( existing, ( size + 2 ) * sizeof *arr );
if ( arr != NULL )
{
arr[size] = malloc( strlen( string ) + 1 );
strcpy( arr[size], string );
arr[size+1] = NULL;
}
return arr;
}
函数free_strings
也不正确。它应该看起来像
void free_strings( char **strings )
{
size_t size` = 0;
do
{
free( strings[size] );
} while ( strings[size++] != NULL );
free( strings );
}