簡體   English   中英

使用“Free()”命令后程序崩潰 (C)

[英]Program crashing after using "Free()" command (C)

我有以下結構:

typedef struct employee
{
    int   name_length;
    char* name;
    float  salary;
} Employee;

以及以下功能:

Employee** makeArr(char* fileName, int* size)
{
    FILE* f = fopen(fileName, "rb");
    checkOpenFile(f);
    Employee** arr = (Employee**)malloc(sizeof(Employee*));
    checkAllocation(&arr);
    int counter = 0;
    while (!feof(f))
    {
        
        int employeeNameSize;
        float employeeSalary;
        fread(&employeeNameSize, sizeof(int), 1, f);
        if (feof(f))
            break;
        char* employeeName = (char*)malloc(sizeof(char) * employeeNameSize+1);
        checkAllocation(&employeeName);
        fread(employeeName, sizeof(char), employeeNameSize, f);
        employeeName[employeeNameSize] = '\0';
        fread(&employeeSalary, sizeof(float), 1, f);
        arr[counter] = makeEmployee(employeeNameSize, employeeName, employeeSalary);
        counter++;
        realloc(arr, sizeof(Employee*)*(counter));
    }
    *size = counter;
    fclose(f);
    return arr;
} 

和:

void freeEmployeeArr(Employee** arr, int size)
{
    for(int i = 0; i < size; i++)
    {
        free(arr[i]->name);
        free(arr[i]);
    }
     free(arr); 
}

和這個:

Employee* makeEmployee(int nameLength, char* name, float salary)
{
    Employee* tmp = (Employee*)malloc(sizeof(Employee));
    checkAllocation(&tmp);
    tmp->name_length = nameLength;
    tmp->name = name;
    tmp->salary = salary;
    return tmp;

}

我的主要:

void main(int argc, char* argv[])
{
    char* name1 = argv[1]; 
    char* name2 = argv[2];
    int size;
    Employee** ans = makeArr(name1, &size);
    freeEmployeeArr(ans, size);
}

我遇到的問題:

free(arr);

使我的程序崩潰。 如果我刪除此行,一切正常。 但這具體給我帶來了一些問題。 如果我試圖在不調試的情況下開始,我會收到以下消息: 在此處輸入圖像描述

如果我正在調試,我會收到以下消息: 在此處輸入圖像描述

我真的不知道我的程序有什么問題。 我讀過當我用零值重新分配/malloc 時,可能會出現這類問題。 但這種情況並非如此。

誰能在這里發現我的錯誤? 提前致謝。

realloc(arr, sizeof(Employee*)*(counter));

不好。 您必須將返回的新指針分配給arr

它應該是這樣的:

Employee** newArr = realloc(arr, sizeof(Employee*)*(counter));
if (newArr == NULL) {
    /* handle error, clean up and return from the function */
}
arr = newArr;

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM