概述
程序处理方式有两种,一种是即使处理,另一种是暂时存期再大块写入的方式,前者往往造成比较大的系统负担,因此C语言往往允许程序猿进行实际的写操作之前控制生产的数据量;
这种控制一般由库函数setbuf()来实现,如果buf是个大小合适的数组,则:
setbuf(stdout,buf);
语句将通知输入/输出库,所有写入到stdout的输出都应该用buf作为输出缓冲区,直到buf缓冲区被填满或者程序猿调用ffiush,缓冲区的buf内存才会实际写道stout输出流中,缓存区的大小由<stdio.h>头文件中的BUFSIZE定义
#include<stdio.h>
int main()
{
int;
char buf[BUFSIZE];
setbuf(stdout,buf);
while((c=getchar())!=EDF)
putchar(c);
}
但是此函数是错误的,由于setbuf的调用,输入/出的所有字符应该先缓存在buf中,但最后一次清空实在main函数结束之后,这就导致buf还没清空,里面的字符就已经被释放了;
解决这个问题的方法有两个:
第一种方法就是将缓冲数组定义为静态数组:
static char buf[BUFSIZE];
第二种方法就是将buf声明完全以动到main之外,这就是动态分配缓存区,动态分配的缓存区是不会被程序主动释放的,所以需要程序猿在使用后主动释放:
char *malloc();
setbuf(stdout,malloc[BUFSIZE]);
最后
以上就是丰富裙子为你收集整理的缓冲输出与内存分配(C语言陷阱)的全部内容,希望文章能够帮你解决缓冲输出与内存分配(C语言陷阱)所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复