1、第9章文件的输入和输出,本章导读,学习完本章以后,你将能够:了解FILE类型及文件指针掌握缓冲文件系统中文件操作一般步骤及特点,教学目的,掌握文件指针,掌握文件的打开和关闭,文件的读写和定位方法。掌握文件的出错检测,文件指针文件的打开和关闭文件的读写和定位,教学重点,教学难点,文件的读写和定位,关键词,文件指针;输入输出,授课时量,理论学时:2,9.1文件的概述9.2文件的打开与关闭9.3文件的顺序读取9.4文件的定位与随机读写9.5文件的出错检测,本章主要内容如下:,9.1 C文件概述文件:存储在外部介质上数据的集合,是操作系统数据管理的单位,使用数据文件的目的1、数据文件的改动不引起程序的
2、改动程序与数据分离2、不同程序可以访问同一数据文件中的数据数据共享3、能长期保存程序运行的中间数据或结果数据,文件分类按文件的逻辑结构:记录文件:由具有一定结构的记录组成(定长和不定长)流式文件:由一个个字符(字节)数据顺序组成按存储介质:普通文件:存储介质文件(磁盘、磁带等)设备文件:非存储介质(键盘、显示器、打印机等)按数据的组织形式:文本文件: ASCII文件,每个字节存放一个字符的ASCII码二进制文件:数据按其在内存中的存储形式原样存放,文本文件特点:存储量大、速度慢、便于对字符操作,二进制文件特点:存储量小、速度快、便于存放中间结果,文件处理方法缓冲文件系统:高级文件系统,系统自动
3、为正在使用的文件开辟内存缓冲区非缓冲文件系统:低级文件系统,由用户在程序中为每个文件设定缓冲区,文件类型指针文件结构体FILE 缓冲文件系统为每个正使用的文件在内存开辟文件信息区文件信息用系统定义的名为FILE的结构体描述FILE定义在stdio.h中,typedef struct int _fd; /文件号 int _cleft; /缓冲区中剩下的字符数 int _mode; /文件操作方式 char *_next; /文件当前读写位置 char *_buff; /文件缓冲区位置FILE;,文件类型指针指针变量说明: FILE *fp;用法:文件打开时,系统自动建立文件结构体,并把指向它的指
4、针返回来,程序通过这个指针获得文件信息,访问文件文件关闭后,它的文件结构体被释放,9.2 文件的打开与关闭C文件操作用库函数实现,包含在stdio.h文件使用方式:打开文件-文件读/写-关闭文件系统自动打开和关闭三个标准文件:标准输入-键盘 stdin标准输出-显示器 stdout标准出错输出-显示器 stderr打开文件fopen函数原型: FILE *fopen(char *name,char *mode),功能:按指定方式打开文件返值:正常打开,为指向文件结构体的指针;打开失败,为NULL,要打开的文件名,使用文件方式,例 文件打开与测试 FILE *fp; fp=fopen(“aa.c
5、”,“w”); if(fp=NULL) printf(“File open error!n”); exit(0); ,例 FILE *fp; fp= fopen (“c:fengyibkctest.dat”,”r”);,例 FILE *fp;char *filename=“c:fengyibkctest.dat”; fp= fopen(filename,”r”);,文件关闭fclose作用:使文件指针变量与文件“脱钩”,释放文件结构体和文件指针函数原型:int fclose(FILE *fp),功能:关闭fp指向的文件返值:正常关闭为0;出错时,非0,文件打开时返回的文件类型指针,不关闭文件可
6、能会丢失数据,9.3文件的顺序读取字符读写:fputc与fgetcfputc函数原型:int fputc(int c, FILE *fp)功能:把一字节代码c写入fp指向的文件中返值:正常,返回c;出错,为EOF,fgetc函数原型:int fgetc(FILE *fp)功能:从fp指向的文件中读取一字节代码返值:正常,返回读到的代码值;读到文件尾或出错,为EOF,文件I/O与终端I/O#define putc(ch,fp) fputc(ch,fp)#define getc(fp) fgetc(fp)#define putchar( c ) fputc(c,stdout)#define get
7、char( ) fgetc(stdin),判断二进制文件是否结束 while(!feof(fp) c=fgetc(fp); . ,例 从键盘输入字符,逐个存到磁盘文件中,直到输入#“为止,#include main() FILE *fp; char ch,*filename=“out.txt”; if(fp=fopen(filename,w)=NULL) printf(cannot open filen);exit(0); printf(Please input string:); ch=getchar(); while(ch!=#) fputc(ch,fp); putchar(ch); ch
8、=getchar(); fclose(fp);,例 读文本文件内容,并显示,feof函数原型: int feof(FILE *fp)功能:判断文件是否结束返值:文件结束,返回真(非0);文件未结束,返回0,main()#include FILE *in, *out; char ch,infile10,outfile10; scanf(%s,infile); scanf(%s,outfile); if (in = fopen(infile, r)= NULL) printf(Cannot open infile.n); exit(0); if (out = fopen(outfile, w)=
9、NULL) printf(Cannot open outfile.n); exit(0); while (!feof(in) fputc(fgetc(in), out); fclose(in); fclose(out);,字符串读写: fgets与fputs函数原型:,fgets(char *s,int n,FILE *fp)fputs(char *s,FILE *fp),功能:从fp指向的文件读/写一个字符串返值:fgets正常时返回读取字符串的首地址;出错或文件尾,返回NULLfputs正常时返回写入的最后一个字符;出错为EOF,例 从键盘读入字符串存入文件,再从文件读回显示,fgets从
10、fp所指文件读n-1个字符送入s指向的内存区,并在最后加一个0(若读入n-1个字符前遇换行符或文件尾(EOF)即结束),fputs把s指向的字符串写入fp指向的文件,#includemain() FILE *fp; char string81; if(fp=fopen(file.txt,w)=NULL) printf(cannt open file);exit(0); while(strlen(gets(string)0) fputs(string,fp); fputs(n,fp); fclose(fp); if(fp=fopen(file.txt,r)=NULL) printf(cannt
11、open file);exit(0); while(fgets(string,81,fp)!=NULL) fputs(string,stdout); fclose(fp);,格式化读写:fprintf与fscanf函数原型:,int fprintf(FILE *fp,const char *format,argument,)int fscanf(FILE *fp,const char *format,address,),功能:按格式对文件进行I/O操作返值:成功,返回I/O的个数;出错或文件尾,返回EOF,fprintf(fp,“%d,%6.2f”,i,t); /将i和t按%d,%6.2f格式
12、输出到fp文件fscanf(fp,“%d,%f”, /若文件中有3,4.5 ,则将3送入i, 4.5送入t,例 从键盘按格式输入数据存到磁盘文件中去,#include main() char s80,c80; int a,b; FILE *fp; if(fp=fopen(test,w)=NULL) puts(cant open file); exit() ; fscanf(stdin,%s%d,s,数据块读写:fread与fwrite函数原型:,size_t fread(void *buffer,size_t size, size_t count,FILE *fp)size_t fwrite(
13、void *buffer,size_t size, size_t count,FILE *fp),功能:读/写数据块返值:成功,返回读/写的块数;出错或文件尾,返回0说明:typedef unsigned size_t;buffer: 指向要输入/输出数据块的首地址的指针size: 每个要读/写的数据块的大小(字节数)count: 要读/写的数据块的个数fp: 要读/写的文件指针fread与fwrite 一般用于二进制文件的输入/输出,例 float f2; FILE *fp; fp=fopen(“aa.dat”,“rb”); fread(f,4,2,fp);,for(i=0;i2;i+) f
14、read(,例 struct student int num; char name20; char sex; int age; float score3; stud10; for(i=0;i10;i+) fread(,例 从键盘输入4个学生数据,把他们转存到磁盘文件中去,#include #define SIZE 2struct student_type char name10; int num; int age; char addr15;studSIZE;main() int i; for(i=0;iSIZE;i+)scanf(%s%d%d%s,studi.name,void save()
15、FILE *fp; int i; if(fp=fopen(d:fengyiexestu_dat,wb)=NULL) printf(cannot open filen); return; for(i=0;iSIZE;i+) if(fwrite(,void display() FILE *fp; int i; if(fp=fopen(d:fengyiexestu_dat,rb)=NULL) printf(cannot open filen); return; for(i=0;i0 向后移动0 向前移动,起始点文件开始 SEEK_SET 0文件当前位置 SEEK_CUR 1文件末尾 SEEK_END
16、 2,例 fseek(fp,100L,0); fseek(fp,50L,1); fseek(fp,-10L,2);,ftell函数函数原型: long ftell(FILE *fp)功能:返回位置指针当前位置(用相对文件开头的位移量表示)返值:成功,返回当前位置指针位置;失败,返回-1L,,例 磁盘文件上有3个学生数据,要求读入第1,3学生数据并显示,#includestdio.h main() FILE *fp; char filename80; long length; gets(filename); fp=fopen(filename,rb); if(fp=NULL) printf(fi
17、le not found!n); else fseek(fp,0L,SEEK_END); length=ftell(fp); printf(Length of File is %1d bytesn,length); fclose(fp); ,例 求文件长度,9.5 出错的检测ferror函数函数原型: int ferror(FILE *fp)功能:测试文件是否出现错误返值:未出错,0;出错,非0说明每次调用文件输入输出函数,均产生一个新的ferror函数值,所以应及时测试fopen打开文件时,ferror函数初值自动置为0,clearerr函数函数原型: void clearerr(FILE
18、*fp)功能:使文件错误标志置为0返值:无说明:出错后,错误标志一直保留,直到对同一文件调clearerr(fp)或rewind或任何其它一个输入输出函数,例 ferror()与clearerr()举例,#include int main(void) FILE *stream; stream = fopen(DUMMY.FIL, w); getc(stream); if (ferror(stream) printf(Error reading from DUMMY.FILn); clearerr(stream); if(!ferror(stream) printf(Error indicator cleared!); fclose(stream); return 0;,本 章 结 束,