processFile函数会将文件中的信息正确扫描到p,但是addNodeLast函数不会将p中的信息添加到链表员工中,因为它会崩溃
有人能帮我修复崩溃,这样它就能把每个节点连接在一起吗?
#include <stdio.h>
#include <stdlib.h>
#include "list.h"
void processFile(NODEPTR *employees, FILE *fp);
void outputPayFile(NODEPTR employees);
FILE *fp;
int main(void) {
NODEPTR employees;
if (fopen_s(&fp, "payfile2.txt", "r") != 0) {
printf("Failed to open payfile.txt for readingn");
exit(0);
}
...missing code...
}
void processFile(NODEPTR *employees, FILE *fp) {
int i = 0;
NODEPTR p;
while(i < 5) {
printf("Entered Loopn");
p = (NODEPTR) malloc(sizeof(node));
fscanf(fp, "%s %s %c %d %c %fn", p->firstName, p->lastName, &(p->gender),
&(p->tenure), &(p->rate), &(p->rate), &(p->salary));
addNodeLast(employees, p);
i++;
}
}
在列表.h:中
void addNodeLast(NODEPTR *list, NODEPTR t) {
NODEPTR p;
if (*list == NULL)
*list = t;
else {
p = *list;
while (p->next)
p = p->next;
p->next = t;
}
}
NODEPTR:的定义
typedef struct node {
char firstName[11];
char lastName[16];
char gender;
int tenure;
char rate;
float salary;
struct node *next;
} node, *NODEPTR;
您从不初始化next
指针。这是一个常见的错误。对malloc
的调用不会使您的内存归零。因此,当您将一个节点添加到非空列表中时,您可能会直接运行到末尾,因为第一个节点的next
指针可能是非空的。
你至少需要这样做:
p = malloc(sizeof(node));
if( p != NULL ) p->next = NULL;
你可以考虑使用calloc
,它做零:
p = calloc(1, sizeof(node));