这是文件与之前的链表结合使用,可以从文件中看数据读出来,形成一条链表,同时也可以把链表的数据写入文件中
filedata头文件
/********************************************************
* *
* ☆☆☆☆☆文件读写 函数的声明 ☆☆☆☆☆ *
* *
********************************************************/
#ifndef _FILEDATA_H_
#define _FILEDATA_H_
#include "list.h"
int FILE_write(int size,char *file,PNode head);
PNode FILE_find_all(int size,char *file);
#endif _FILEDATA_H_
#include "filedata.h"
#include "list.h"
/*********************************************
*函数名称:int FILE_write(int size,char *file,PNode NodeHead)
*功能描述:对链表的内容全部写到对应的文件中
*参数说明:size [IN] 输入数据的大小
file [IN] 写入到哪个文件
NodeHead [IN]链表头结点
*返回值: 成功返回SUCCESS,失败返回FAILURE
*********************************************/
int FILE_write(int size,char *file,PNode NodeHead)
{
FILE *pf;
PNode tempnode=NULL;
PNode curnode=NULL;
tempnode=NodeHead;
if ((pf=fopen(file,"wb+"))==NULL)
{
printf("文件打开失败!\n");
return FAILURE;
}
if (0!=fclose(pf))
{
printf("文件关闭失败!");
return FAILURE;
}
if ((pf=fopen(file,"ab+"))==NULL)
{
printf("文件打开失败!\n");
return FAILURE;
}
while(tempnode!=NULL)
{
if (tempnode->next!=NULL) //判断下一个结点是否存在
{
curnode=tempnode->next;
}
else
{
curnode=NULL;
}
if (1!=fwrite(tempnode->data,size,1,pf))
{
printf("数据写入失败!\n");
return FAILURE;
}
fflush(pf); //刷新缓冲区
tempnode=curnode;
}
if (0!=fclose(pf))
{
printf("文件关闭失败!");
return FAILURE;
}
return SUCCESS;
}
/*********************************************
*函数名称:PNode FILE_find_all(int size,char *file)
*功能描述:对链表的内容全部写到对应的文件中
*参数说明:size [IN] 输入数据的大小
file [IN] 读哪个文件
*返回值: 成功返回头结点,失败返回NULL
*********************************************/
PNode FILE_find_all(int size,char *file) //用于读取文件数据,并存储到链表到去
{
int Inode=0;
int Icount=0;
void *data;
FILE *pf;
if ((pf=fopen(file,"rb+"))==NULL)
{
printf("文件打开失败!\n");
return NULL;
}
data=(void*)malloc(size); //给data分配空间,用于存放数据
memset(data,0,size);
while (0!=fread(data,size,1,pf))
{
Icount++;
if (Inode==0)
{
if ((NodeHead=List_init(data))==NULL)//对头结点进行初始化,如果失败就返回
return NULL;
Inode++;
}
else
{
if (List_add(data,NodeHead)==FAILURE) //如果头结点初始化成功,就进行继续读取
{
printf("添加数据失败\n");
return NodeHead; //如果读取失败就,就返回
}
}
data=(void*)malloc(size); //继续为下一个数据分配空间
memset(data,0,size);
}
free(data); //释放最后一个没有使用的空间
if (0!=fclose(pf))
{
printf("文件关闭失败!");
}
if (Icount==0)
{
return NULL;
}
return NodeHead;
}