从文件读取到链接列表时出现问题

时间:2019-05-04 19:52:11

标签: c linked-list file-read

我正在尝试创建一个功能,该功能从文本文件中读取孩子的名字并将其写入链接列表中。我有一个将其写入列表的结构,因为整个列表都是用文件中的姓氏填充的。

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

typedef struct Child child;

struct Child {
    char *name;
    child *next;
};

void readFromFile(char fileName[], child **head) {
    FILE *file;

    if (!(file = fopen(fileName, "rt"))) {
        printf("Can't open file\n");
        abort();
    } else {
        static char buffer[1024];
        while (fgets(buffer, 1024, file)) {
            child *new = (child *)malloc(sizeof(child));
            new->name = buffer;
            new->next = (*head);
            (*head) = new;
        }
    }
    fclose(file);
}

void printList(child *head) {
    child *tmp = head;
    while (tmp) {
        printf("%s", tmp->name);
        tmp = tmp->next;
    }
}

int main() {
    child *head = NULL;

    readFromFile("file.txt", &head);
    printList(head);

    return 0;
}

文件包含以下样式的数据:

John
Ann
Adam
Arthur

1 个答案:

答案 0 :(得分:1)

您的读取循环使所有节点都指向同一静态数组:

    static char buffer[1024];
    while (fgets(buffer, 1024, file)) {
        child *new = (child *)malloc(sizeof(child));
        new->name = buffer;
        new->next = (*head);
        (*head) = new;
    }

您应该为每个节点分配一个字符串副本:

    char buffer[1024];
    while (fgets(buffer, sizeof buffer, file)) {
        child *new_node = (child *)malloc(sizeof(child));
        new_node->name = strdup(buffer);
        new_node->next = *head;
        *head = new_node;
    }

还建议检查内存分配失败,并避免使用c ++关键字。您可能还希望从缓冲区中删除尾随换行符以及任何前导或尾随空格。