UNIX 环境高级编程之带缓冲 I/O 与不带缓冲 I/O 的区别
程序员文章站
2022-03-01 18:17:20
1、I/OI/O 操作可根据是否带缓冲区来分类为带缓冲的 I/O 和不带缓冲区的 I/O ,后者就是标准 I/O。那么这两者有啥区别呢?不带缓冲其实就是应用程序直接使用系统调用。标准 I/O 是在系统调用上做了一层封装,替用户做了相关优化操作,从而减少应用程序的系统调用次数,从而达到一定的性能优化。比如需要写 100 字节数据到磁盘文件。内核的缓冲大小为 100 字节,假设用户不知道内......
1、I/O
I/O 操作可根据是否带缓冲区来分类为带缓冲的 I/O(标准 I/O) 和不带缓冲区的 I/O 。
那么这两者有啥区别呢?
不带缓冲其实就是应用程序直接使用系统调用。
标准 I/O 是在系统调用上做了一层封装,替用户做了相关优化操作,从而减少应用程序的系统调用次数,从而达到一定的性能优化。
比如需要写 100 字节数据到磁盘文件。
内核的缓冲大小为 100 字节,假设用户不知道内核的缓冲区大小,采用不带缓冲的函数写,每次写 10 个字节,总共写了 10 次,即 10 次 write 的系统调用。
同样用户不知道内核的缓冲区大小,调用带缓冲的函数 fwrite,它的缓冲区大小为 50 字节,一旦用户调用 fwrite 5 次,就会写满其缓冲区,于是 fwrite 会调用一次 write 将数据写到磁盘文件,剩下的 50 字节再调用一次 write ,总共就调用了 2 次系统调用。
不带缓冲的 I/O 函数:
int open(const char * pathname, int flags);
ssize_t read(int fd, void * buf, size_t count);
ssize_t write(int fd, const void * buf, size_t count);
off_t lseek(int fildes, off_t offset, int whence);
int close(int fd);
注:除了 read、write 外都不存在数据的存储问题, read、write 需要开发者提供一个存储空间,这个空间大小是由开发者来决定的,不同的大小有可能带来 I/O 操作的不同性能。
再来看看部分标准 I/O 的函数:
FILE *fopen(const char *filename, const char *mode);
int fclose(FILE * fp);
int fgetc(FILE *fp)
char * fgets(char * s, int n,FILE *stream);
int fputs(char * string, FILE * stream);
本文地址:https://blog.csdn.net/chuanglan/article/details/85945949