我的代码:
#include "stdafx.h"
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define NAME_LEN 30
#define LINE_LEN 80
struct record {
char *firstname;
char *lastname;
long int idnumber;
int ccode;
long int phonenum;
struct record *next;
};
typedef struct record STUDENT;
STUDENT *header; /* pointer to the start of linked list */
char fname[NAME_LEN], lname[NAME_LEN];
char filename[LINE_LEN];
long int id, phone;
int course;
FILE *fptr;
STUDENT *makenode(long int stud_id, int c_code, long int phone, char *fname, char *lname);
void insert_node();
void delete_node();
void search_node();
void print_list();
void output_list();
int main()
{
int choice;
STUDENT *p, *q;
q = NULL;
printf(" Enter the input file name: ");
gets_s(filename);
fptr = fopen_s(filename, "r");
if (fptr == NULL)
printf("Error, can't open the input file %s \n", filename);
else
{
while (!feof(fptr))
{
fscanf(fptr, " %s %s %ld %d %ld", fname, lname, &id, &course, &phone);
/* printf("%s %s %ld %d %ld \n",fname, lname,id,course,phone);*/
p = makenode(id, course, phone, fname, lname);
p->next = q;
q = p;
}
printf("Created the Linked List\n");
header = q;
fclose(fptr);
do {
printf("\n\n MENU \n\n");
printf("1. Insert\n");
printf("2. Delete\n");
printf("3. Search\n");
printf("4. List\n");
printf("5. Save\n");
printf("6. Quit\n");
printf("\n");
printf("Enter your choice: "); /*Prompt user*/
scanf("%d", &choice);
switch (choice)
{
case 1:
insert_node();
break;
case 2:
delete_node();
break;
case 3:
search_node();
break;
case 4:
print_list();
break;
case 5:
output_list();
break;
}
} while (choice != 6);
return 0;
}
}
/***************************************************************/
STUDENT *makenode(long int stud_id, int c_id, long int phone, char *fname, char *lname)
{
STUDENT *ptr;
ptr = (STUDENT *)malloc(sizeof(STUDENT));
if (ptr != NULL)
{
ptr->next = NULL;
ptr->firstname = (char *)malloc(strlen(fname) + 1);
strcpy(ptr->firstname, fname);
ptr->lastname = (char *)malloc(strlen(lname) + 1);
strcpy(ptr->lastname, lname);
ptr->idnumber = stud_id;
ptr->ccode = c_id;
ptr->phonenum = phone;
return(ptr);
}
else
{
printf("Memory not allocated\n");
}
}
/************************************************************/
void insert_node()
{
}
/************************************************************/
void delete_node()
{
}
/***********************************************************/
void search_node()
{
}
/**********************************************************/
void output_list()
{
}
/********************************************************/
void print_list()
{
STUDENT *p1;
p1 = header;
while (p1 != NULL)
{
printf("%s %s %ld %d %ld\n", p1->firstname,
p1->lastname, p1->idnumber, p1->ccode, p1->phonenum);
p1 = p1->next;
}
}
/********************************************************/
我按照错误的说明操作。我将gets
和fopen
更改为gets_s
和fopen_s
,但我收到了以下错误:
答案 0 :(得分:0)
gets_s()
和fopen_s()
采用与gets
和fopen
不同的参数。 gets_s()
占用接收缓冲区的大小:
gets_s(filename, sizeof filename);
和fopen_s()
指向FILE*
:
if (fopen_s(&fptr, filename, "r"))
printf("Error, can't open the input file %s\n", filename);
fopen_s
返回错误代码。如果失败,您可以使用strerror()
保存并获取相应的错误消息。
另请注意,while(!feof(fptr))
循环无法在文件末尾正确停止,它可能会复制最后一组值。请参阅Why is “while ( !feof (file) )” always wrong?并以这种方式修复代码:
while (fscanf(fptr, " %s %s %ld %d %ld", fname, lname, &id, &course, &phone) == 5)) {
/* printf("%s %s %ld %d %ld\n",fname, lname,id,course,phone); */
p = makenode(id, course, phone, fname, lname);
p->next = q;
q = p;
}
链接列表的方式将实际反转文件内容中节点的顺序,可能不是您打算做的。
使用scanf("%d", &choice);
获取用户选择是有风险的:如果用户键入非数字,非空格字符,程序将进入无限循环。至少检查scanf
的返回值,或者从用户那里获取一行,测试文件结尾,并使用sscanf()
来解析用户选择。
如果内存分配失败,您只测试三个潜在故障中的一个,然后只打印一条消息。您应该返回NULL
并在调用函数中对其进行测试,或者使用exit()
或abort()
中止该程序。