c语言怎么将一个单向链表读写二进制文件(fwrite和fread)。在结构有两个以上的元素时。

2024-11-29 00:09:32
推荐回答(2个)
回答1:

Student是结构体声明。
//从文件中读取链表数据,读取文件直到结束,new_count是统计读取到的对象个数
Student *new_file_student_null(int *new_count)
{
Student *head=NULL,*newp,*end,*fnext;
FILE *fp;
char fname[80]; //存放文件名
*new_count=0; //暂时是读取到0个对象

//打开要读取的二进制文件
printf("请输入包含路径的文件名:\n");
gets(fname);
if((fp=fopen(fname,"rb"))==NULL)
{
printf("读取文件%s失败\n",fname);
exit(0);
}

//读取文件直到文件结束:开辟一个空间,读取一个存入该空间!
while(1)
{
//开辟新空间,空间大小为结构体Student
newp=(Student *)malloc(sizeof(Student));
if(newp==NULL) //开辟空间出问题
{
printf("开辟空间出问题\n");
exit(0); //退出整个程序
}

//链表连接新空间组成新链表
if(head==NULL) //链表是空时
{
head=end=newp;
}
else //链表非空
{
fnext=end; //fnext指向最后一个有数据的值
*new_count+=1; //已经读取到1个有效数据,所以加1
end->next=newp;
end=newp;
}

//读取文件存入新开辟的空间。
//读取完文件获得0值,需要对最后一个有效值设置next指向NULL,以及释放最后一块开辟的内存newp,并且退出死循环
if(fread(end,sizeof(Student),1,fp)==0)
{
if(head==newp)head=NULL; //newp是准备释放的最后一个,head指向它表示前边没有有效数据,即没有任何数据,理应指向NULL
else fnext->next=NULL; //最后一个有效值的next指向NULL

free(newp); //最后一个有效值在newp之前,即newp这个新开辟的空间没有使用到。
break;
}
}
fclose(fp); //关闭文件
return (head);
}

//链表全部数据保存到指定的二进制文件中,返回链表对象数量
int save_student(Student *head)
{
Student *p; //逐个读取链表对象
FILE *fp;
char fname[80]={0}; //存放输入的文件路劲名称
int count=0; //暂时保存到0个对象

//打开文件
printf("请输入要保存的文件名路径\n");
gets(fname);
if((fp=fopen(fname,"wb"))==NULL) //打开文件准备写入二进制文件
{
printf("打开文件%s失败",fname);
exit(0); //退出整个程序
}

//链表保存到文件
for(p=head;p!=NULL;p=p->next)
{
count+=fwrite(p,sizeof(Student),1,fp);
}

fclose(fp); //关闭文件
return (count);
}

回答2:

将每个结点单独用fwrite()写入文件即可,读取时也用fread()逐个读取即可。