有哪些缓冲类型
这篇文章主要介绍“有哪些缓冲类型”,在日常操作中,相信很多人在有哪些缓冲类型问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”有哪些缓冲类型”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
缓冲
为了减少使用read和write调用的次数,标准IO库提供了缓冲,有人可能会问,为什么要减少它们的调用次数?很明显read和write是系统调用,它们花费的时间将会更多,本文不展开描述。那么有哪三种缓冲类型呢?
全缓冲
在全缓冲的情况下,在填满标准I/O缓冲区后,才进行实际的I/O操作。写磁盘文件通常就是全缓冲的。举个例子:
#include<stdio.h> #include<unistd.h> int main(void) { FILE *fp = fopen("./test.txt","w+"); if(NULL == fp) { perror("open file failed"); return -1; } char buf[] = "wechat:shouwangxiansheng\n"; fwrite(buf,sizeof(char),sizeof(buf),fp); //fflush(fp); sleep(20); fclose(fp); return 0; }
打开一个文件,并向里面写入一段字符串。我们编译并运行:
$ gcc -o buff buff.c $ cat test.txt wechat:shouwangxiansheng $ ./buff
此时观察test.txt:
$ cat test.txt
发现它的内容是空!明明已经写入了为什么会什么东西都没有?原因在于它默认是全缓冲的,因此在将内容写入文件后,并没有直接存在文件中,当程序关闭文件或者程序运行完成退出后,再次查看:
发现文件已经有了内容。除了等待程序运行完成,还可以使用fflush函数,它可以将缓冲区中的内容写入到磁盘中(终端驱动设备表示丢弃缓冲区的数据)。所以将fwrite下面一行的注释去掉后,就可以发现,写入之后,就可以直接在文件中看到内容了。所以当你在写一个文件,但是查看文件却没有任何写入内容时,不要一直怀疑自己的代码。
行缓冲
行缓冲指的是当遇到换行符时,或者缓冲区已经满了(一般1024字节),标准I/O库执行I/O操作。同样举个例子:
#include<stdio.h> #include<unistd.h> int main(void) { printf("wechat:shouwangxiansheng"); sleep(10); return 0; }
编译运行上面的程序:
$ gcc -o lineBuff lineBuff.c $ ./lineBuff
你会发现,printf执行完了之后,内容并没有马上输出到终端,而是在程序运行完之后才输出。聪明的你当然也知道,要想打印完后直接输出到终端,只需要改成下面这样就可以了:
printf("wechat:shouwangxiansheng\n");
不带缓冲
这个从字面就可以理解其意思了。同样举个例子:
noBuff.c*/ #include<stdio.h> #include<unistd.h> int main(void) { fprintf(stderr,"wechat:shouwangxiansheng"); sleep(10); return 0; }
编译运行你就会发现,运行完fprintf语句后,内容直接输出在终端,而不需要等到换行。一般来说,标准错误是不带缓冲的。
总结
通过上面的一些例子,我们也发现了这样一些规律:
通常磁盘上的文件是全缓冲区的
标准输入和标准输入通常是行缓冲的
指向终端设备的流通常是行缓冲,而指向文件时,则是全缓冲
为了尽可能显示错误信息,标准错误是不带缓冲的
到此,关于“有哪些缓冲类型”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341