内存泄漏的C问题(重新分配功能)

时间:2020-05-31 18:31:49

标签: c memory-management memory-leaks heap-memory realloc

scanFolderPath-包含文件的文件夹的路径。

filesToScan-具有文件名的字符串数组。

我对realloc行(for循环中的第三行)有问题。而且我不明白为什么!感谢您对程序员社区的帮助;)

char* filePath = malloc(0);
char* fileContent = 0;
char* partContent = 0;
FILE* fileToScan;
int i = 0, j = 0, virus = FALSE, flag = FALSE, counter = 0;
for (i = 0; i < amountOfFiles; i++)
{
    flag = FALSE;
    if (scanFolderPath != NULL && filesToScan[i] != NULL)
    {
        realloc(filePath, (sizeof(char) * (strlen(scanFolderPath) + 1 + strlen(filesToScan[i]))));
    }
    strcpy(filePath, "");
    getFilePath(filePath, scanFolderPath, filesToScan[i]);
    fileToScan = fopen(filePath, "rb");
    readFile(&fileContent, filePath);
    if (choice == '0')
    {
        virus = scanSingature(fileContent, virusSingature, getLength(fileToScan), virusSingatureLen);
        if (virus)
        {
            printf("%s - Infected!\n", filePath);
            fprintf(logsFile, "%s", filePath);
            fprintf(logsFile, "  Infected!\n");
        }
        else
        {
            printf("%s - Clean\n", filePath);
            fprintf(logsFile, ("%s", filePath));
            fprintf(logsFile, "  Clean\n");
        }
        fclose(fileToScan);
        strcpy(filePath, "");
    }
}

2 个答案:

答案 0 :(得分:1)

尝试

filePath = realloc(filePath, (sizeof(char) * (strlen(scanFolderPath) + 1 + strlen(filesToScan[i]))));

以这种方式重新分配文件路径的内容,并将指针返回到文件路径

答案 1 :(得分:0)

realloc返回新分配的块。您没有分配任何内容,因此重新分配的内存会丢失,并且指针会在重新分配成功的情况下指向无效内存)。

重新分配的正确方法:

void *p = malloc(10);
void t;

/* ... */

t = realloc(p, 20);
if(t) p = t;            //check if the realloc was successful 

/* ... */

free(p)
相关问题