setbuf使用细节

本文探讨了C语言中标准输出的缓冲机制,通过不同放置fflush函数位置的实验,揭示了其对输出流的影响。当fflush位于putchar之前,会导致输出缺失;位于putchar之后,能确保字符立即输出;而在main函数结束前调用,则可能导致乱码,因局部变量buf被释放。解决方案包括使用全局变量、static关键字或在循环后调用fflush。
摘要由CSDN通过智能技术生成
#include <stdio.h>
int main()
{
   int c;
   char buf[BUFSIZ];
   setbuf(stdout, buf);
   while((c=getchar())!='b')
	{
            putchar(c);
	    fflush( stdout );
	}

   return 0;
}

setbuf(stdout, buf);==>之后的每一次使用putchar函数在调用fflush函数就把该字符写到buf中,等main函数返回后就把缓存里面的东西打印出来。


 

#include <stdio.h>
int main()
{
   int c;
   char buf[BUFSIZ];
   setbuf(stdout, buf);
   while((c=getchar())!='b')
	{
	   	fflush( stdout );//更改位置
                 putchar(c);
	}

   return 0;
}

当更改fflush函数的位置后,输出相比输入会缺少一个

原因:当读到1,fflush() 执行一次空操作,接着遇到putchar(),然后把当前字符存到buf中。进如第二次循环,读取到2,但是fflush()此刻才把buf(内容为1)中的内容读走。进入第三次循环,读取到3,但是fflush()此刻才把buf(内容为1,2)中的内容读走。进入第四次循环,读取到‘b’,退出while循环。main函数返回,输出12


 

#include <stdio.h>
int main()
{
   int c;
   char buf[BUFSIZ] ;
   setbuf(stdout, buf);
   while((c=getchar())!='b')
	{
        putchar(c);
	}

   return 0;
}

 

 

输出乱码,为什么?当main函数返回时,buf为局部变量,被释放掉。buf里面的内容没有被及时读走,所以输出乱码

 

解决办法:把buf变量声明为全局变量,或者使用static关键字,或者在退出while循环之后使用fflush()函数

 

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值