☂️3.2 文本行输入输出函数fgets、fputs
👓写入fputs:
int fputs( const char *string, FILE *stream )
👓读取fgets:
char *fgets( char *string, int n, FILE *stream )
☂️3.3 格式化输入输出函数fscanf、fprintf
👓写入fprintf:
int fprintf( FILE *stream, const char *format [, argument ]...)
🏀对比学习:
🏀例:
👓读取fscanf:
int fscanf( FILE *stream, const char *format [, argument ]... )
🏀对比学习:
🏀例:
☂️3.4 二进制输入输出fread、fwrite
👓写入fwrite:
size_t fwrite( const void *buffer, size_t size, size_t count, FILE *stream )
🏀解释:把buffer里面count个size大小的数据写到流里面
🏀例:
👓读取fread:
size_t fread( void *buffer, size_t size, size_t count, FILE *stream )
🏀解释:从流里面读取count个size大小的数据到buffer里
☂️3.5 三组函数的对比
🏀第一组:
scanf:针对标准输入的格式化的输入语句---stdin
printf:针对标准输出的格式化的输出语句---stdout
🏀第二组:
fscanf:针对所有输入流的格式化的输入语句---stdin
fprintf:针对所有输出流的格式化的输出语句---stdout
🏀第三组:
sscanf:从一个字符串中读取一个格式化的数据;比如:
sprintf:把格式化的数据,转换成字符串;比如:我们把结构体数据转换成字符串!
☂️3.6 文件的随机读写
👓fseek调整指针到任意位置
根据文件指针的位置和偏移量来定位文件指针。
int fseek( FILE * stream, long int offset, int origin )
我们前面学到的fgetc是按照顺序读写一个字符,比如:abcdef,我们读完一个字符a指针就会自动往后偏移到b,只能按顺序一个一个读取!但如果我们只想读取一个指定字符呢?这就需要fseek去调整指针的位置,然后再用fgetc打印!
👓ftell相对于起始位置的偏移量
返回文件指针相对于起始位置的偏移量
long int ftell ( FILE * stream )
👓rewind指针回到起始位置
让文件指针的位置回到文件的起始位置
void rewind ( FILE * stream )
🎩4. 文本文件和二进制文件
🏀根据数据的组织形式,数据文件被分为:文本文件和二进制文件;
🏀数据在内存中以二进制的形式存储,如果不加转换的输出到外存,就是二进制文件
🏀以ASCII字符的形式存储的文件就是文本文件
🏀一个数据在文件中是怎样存储的?
答:字符一律以ASCII形式存储,数值型数据既可以用ASCII形式存储,也可以使用二进制形式存储!例如:整数10000,以ASCII的形式输出到磁盘,在磁盘中占用5个字节(每个字符一个字节),而以二进制形式输出,是一个(int)型整数;则在磁盘上只占4个字节
☂️文本文件形式
☂️二进制文件形式
🎩5. 文件读取结束的判定
☂️被错误使用的feof
牢记:在文件读取过程中,不能用feof函数的返回值直接用来判断文件的是否结束。
而是应用于当文件读取结束的时候,判断是读取失败结束,还是遇到文件尾结束。
🏀文本文件读取是否结束,判断返回值是否为 EOF ,或者 NULL
例如:
1) fgetc判断是否为EOF(-1);正常读取的时候,返回的是读取到的字符的ASCII码值;
2) fgets判断返回值是否为NULL;正常读取的时候,返回存放字符串的空间起始地址;
🏀二进制文件的读取结束判断,判断返回值是否小于实际要读的个数。
例如:
1)fread判断返回值是否小于实际要读的个数;正常读取的时候,返回的是实际读取到的完整元素的个数;
🏀判断结束的原因,在使用feof函数来判断
☂️例:把一个文件的内容拷贝到另一个文件
🎩6. 文件缓冲区
🏀ANSIC 标准采用“缓冲文件系统”处理的数据文件的,所谓缓冲文件系统是指系统自动地在内存中为程序中每一个正在使用的文件开辟一块“文件缓冲区”。
🏀从内存向磁盘输出数据会先送到内存中的缓冲区,装满缓冲区后才一起送到磁盘上。如果从磁盘向计算机读入数据,则从磁盘文件中读取数据输入到内存缓冲区(充满缓冲区),然后再从缓冲区逐个地将数据送到程序数据区(程序变量等)。
🏀缓冲区的大小根据C编译系统决定的。
☂️例:验证缓冲区的存在
结论:因为有缓冲区的存在,C语言在操作文件的时候,需要做刷新缓冲区或者在文件操作结束的时候关闭文件。如果不做,可能导致读写文件的问题。