我是靠谱客的博主 丰富裙子,这篇文章主要介绍缓冲输出与内存分配(C语言陷阱),现在分享给大家,希望可以做个参考。

程序处理方式有两种,一种是即使处理,另一种是暂时存期再大块写入的方式,前者往往造成比较大的系统负担,因此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语言陷阱)内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(124)

评论列表共有 0 条评论

立即
投稿
返回
顶部