分析web缓冲问题

发布时间:2021-11-05 16:36:00 作者:iii
来源:亿速云 阅读:133

这篇文章主要介绍“分析web缓冲问题”,在日常操作中,相信很多人在分析web缓冲问题问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”分析web缓冲问题”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

更改缓冲类型

在上一篇中说到了一些默认的缓冲类型,例如:

那么这些默认的缓冲类型如何修改?有几个函数可以用来更改缓冲类型:

#include<stdio.h> void setbuf(FILE *stream, char *buf); void setbuffer(FILE *stream, char *buf, size_t size); void setlinebuf(FILE *stream); int setvbuf(FILE *stream,char *buf, int mode, size_t size);

参数说明如下:

这里有四个相关函数,作用类似,只是修改范围不一。

setbuf函数中,如果buf设置为NULL,则缓冲关闭;否则指向长度为BUFSIZ长度的缓冲区,并且是行缓冲。

#include<stdio.h> #include<unistd.h> int main(void) {     setbuf(stdout,NULL);     printf("bianchengzhuji");     sleep(10);     return 0; }

这里设置为不带缓冲,则会忽略buf和size参数。设置为全缓冲或者行缓冲的时候。并且buf为NULL,会使用合适长度的系统buffer,否则使用用户自定义buffer。缓冲区的设置就介绍到这里。

fputs没有及时输出

其实在有了前面的基础之后,很多问题就迎刃而解了。

看看下面的例子:

#include<stdio.h> #include<unistd.h> int main(void) {     //setbuf(stdout,NULL);     fputc('a',stdout);     sleep(10);     return 0; }

比如你就想输出一个字符,就打印到终端,但是按照上面的方法,字符并不会被及时输出到终端,因此它默认是行缓冲的。打开注释行,设置为不带缓冲就可以了。

printf打印的日志没有输出

不知道你有没有遇到过这样的情况,准备调试某一个bug,发现每次运行到某个地方,打印就结束了,然后就挂了,让你误以为程序执行到打印的地方就结束了,然而有可能程序执行到后面,只是由于打印是行缓冲的,导致部分打印没有出来,很可能就是你没有加上换行符打印而已。

这时候你可以设置为不带缓冲,或者关键位置fflush,或者打印记得加上换行符。

fflush之后文件还是丢失了

看完前面的内容之后,是不是觉得豁然开朗了?别高兴的太早。

以上措施并不是万事大吉。

你可能会踩到什么坑?

如果你目前还没有遇到过这样的问题,那么你就需要格外注意了。虽然前面fflush等措施将缓冲区的内容进行了I/O操作,但是操作系统还需要将文件系统的buffer写入磁盘,因此马上直接复位会导致文件丢失!怎么办呢?可以使用:

到此,关于“分析web缓冲问题”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

推荐阅读:
  1. 关于 Linux 下后台执行 Python 脚本的缓冲问题
  2. Web开发乱码问题原理分析

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

web

上一篇:怎么理解并掌握的Go高级并发模式计时器

下一篇:如何进行RedHat 7 yum源替换

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》