C语言标准I/O库中流的读写与定位
来源:互联网 发布:雕刻机路径编程软件 编辑:程序博客网 时间:2024/06/05 22:44
不同于像read,write这样围绕文件描述符进行直接I/O的函数,C语言标准I/O库中的操作都是围绕流进行的。当我们打开或创建一个文件时,就会将一个流与该文件关联。
在流式的I/O操作中,系统会为操作分配缓冲区,以减少对read、write的调用次数。这是因为read、write是系统调用,调用所耗费的时间要大于普通的函数调用,为什么更耗时我是这样理解的:read、write针对的是文件也即是磁盘中数据的读写操作,而缓冲区则是在内存中开辟的一块空间,显然计算机对于内存的读写操作是要快于磁盘的。通过缓冲区这样的机制,我们可以提高对于文件的频繁读写操作的效率。
流式的I/O并不总是能提高效率,比如我们要将一个远大于缓冲区容量的数据块一次性写入或读出文件时,缓冲区的机制反而会使系统调用的次数增加,使得效率降低。
当打开一个流时,fopen函数会返回一个文件指针(FILE*), FILE对象是一个结构,里面存放着管理一个流所相关的信息,包括用于实际I/O的文件描述符、指向该流缓冲区的指针、缓冲区大小、及缓冲区中当前的字符数等。而标准I/O库中的函数则都是围绕文件指针进行的。
下面用一段代码展示用于流的读写及定位的几个函数的使用方法。
#include <stdio.h>#include <string.h>int main() { FILE *fp; //定义一个文件指针 char s1[10], s2[] = "abc"; long offset; //变量offset用于记录文件偏移量 fp = fopen("text", "w+"); //以读写的方式创建并打开一个文件 fputs(s2, fp); //将s2写入文件 rewind(fp); //将文件位置设置在起始位置 fgets(s1, sizeof(s1), fp); //从文件读取数据到s1 fputs(s1, stdout); //将s1写入标准输出 putchar('\n'); offset = ftell(fp); //获取当前的文件位置 strcpy(s1,"bcd"); fputs(s1, fp); fseek(fp, 0, SEEK_SET); //将文件位置设置为起始位置 //对于文本文件,一定要选用参数SEEK_SET fgets(s1, sizeof(s1), fp); fputs(s1, stdout); putchar('\n'); fseek(fp, offset, SEEK_SET); //将文件位置设置为offset所指位置 fgets(s1, sizeof(s1), fp); fputs(s1, stdout); putchar('\n'); return 0;}
输出结果
abcabcbcdbcd
阅读全文
0 0
- C语言标准I/O库中流的读写与定位
- C语言_标准I/O库
- C语言文件读写标准I/O库函数的相关操作
- C语言标准I/O
- C标准I/O库
- 理解C语言标准I/O函数
- C语言标准I/O文件操作
- 标准I/O库与Unbuffered I/O(不带缓冲的I/O)函数
- C标准I|O与Unbufferd I|o
- C标准I/O库函数与无缓存的I/O函数
- 标准 C I/O
- C标准I/O
- 标准 C I/O
- 标准C I/O
- linux文件设备与I/O:C标准I/O函数与无缓冲I/O
- Linux-(C)文件读写实例(系统调用/标准I/O库)
- 文件I/O与标准I/O的区别
- Linux - 标准I/O库与高级I/O库
- python数据分析与挖掘项目实战记录
- 实验五 二叉树的操作
- python K-Means聚类算法的实现
- 第8章 指针 ——指针变量做函数参数
- MongoDb 分页 SpringDataPageable MongoRepository
- C语言标准I/O库中流的读写与定位
- 第四周学习内容
- 疯狂Spring Cloud连载(24)Zuul路由配置
- HDU 5690-All X
- NSTimer的循环引用问题
- mysql存储过程案例(插入100条数据)
- Django项目
- hdoj-1711Number Sequence(数组Kmp)
- HDU 1312 Red and Black