C语言 FileStreaming buffer

setbuf

void setbuf ( FILE * stream, char * buffer ); Set stream buffer

  1. 设置文件描述符的缓冲区大小
  2. stream buffer是一个 block of data,在i/o操作和 physical file(文件) 之间
  3. output buffers,写出:数据会放在buffer区,直到填满,然后会flushed(发送给 物理文件并清空buffer区)
  4. input buffers,也是如此
  5. Stream buffers can be explicitly flushed by calling fflush, fclose and freopen或者程序terminates normally(正常终止)会自动调用fllush
  6. 所有打开的文件都默认带有buffer
  7. stdin and stdout are fully buffered by default if they are known to not refer to an interactive . Otherwise, they may either be line buffered or unbuffered by default
  8. 通过setvbuf 改变缓冲方式
参数描述
streamFILE object
buffer存放buffer的数组
#pragma warning(disable:4996)

#include<stdio.h>
#include<stdlib.h>

int main()
{
	char buf[BUFSIZ];
	printf("缓冲区大小是%d字节\n", BUFSIZ);
	setbuf(stdout, buf);
	puts("hello world");  //屏幕此时没有输出,因为存在buf数组里
	system("pause");
	fflush(stdout);  //屏幕输出
	system("pause");
	return(0);
}

setvbuf

int setvbuf ( FILE * stream, char * buffer, int mode, size_t size );Change stream buffering

  1. 设置缓冲方式(Full buffering,Line buffering,No buffering)
参数描述
streamPointer to a FILE object
bufferUser allocated buffer. Shall be at least size bytes long.如果空,会自动设置默认buffer(BUFSIZ)
mode三种
sizeBuffer size, in bytes.
mode描述
_IOFBFFull buffering,写出:buffer区间满,刷新,读入:buffer空,刷新
_IOLBFLine buffering,写出:buffer区满或碰到换行符,刷新,读入:buffer空,或换行符,刷新
_IONBFNo buffering,没有缓冲区,buffer and size参数被忽略
返回描述
成功返回0
失败非0
#pragma warning(disable:4996)

#include<stdio.h>
#include<stdlib.h>

int main()
{
	setvbuf(stdout, NULL, _IONBF, 512);
	puts("hello world"); //直接输出到屏幕,不需要刷新缓冲区
	system("pause");
	fflush(stdout);
	system("pause");
	return(0);
}

fflush

int fflush ( FILE * stream ); Flush stream

  1. 刷新缓冲区

参考:
http://www.gnu.org/software/libc/manual/html_node/I_002fO-on-Streams.html#I_002fO-on-Streams

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Ring Buffer(环形缓冲区)是一种循环使用的缓冲区,常用于实现数据的异步传输。下面是一个简单的C语言实现环形缓冲区的代码示例。 ```c #include <stdio.h> #include <stdlib.h> #define BUFFER_SIZE 10 typedef struct { int *buffer; int head; int tail; int size; } RingBuffer; RingBuffer *create_ring_buffer(int size) { RingBuffer *rb = (RingBuffer *)malloc(sizeof(RingBuffer)); rb->buffer = (int *)calloc(size, sizeof(int)); rb->head = 0; rb->tail = 0; rb->size = size; return rb; } void destroy_ring_buffer(RingBuffer *rb) { free(rb->buffer); free(rb); } int is_empty(RingBuffer *rb) { return rb->head == rb->tail; } int is_full(RingBuffer *rb) { return (rb->tail + 1) % rb->size == rb->head; } void push(RingBuffer *rb, int value) { if (is_full(rb)) { printf("Ring buffer is full!\n"); return; } rb->buffer[rb->tail] = value; rb->tail = (rb->tail + 1) % rb->size; } int pop(RingBuffer *rb) { if (is_empty(rb)) { printf("Ring buffer is empty!\n"); return -1; } int value = rb->buffer[rb->head]; rb->head = (rb->head + 1) % rb->size; return value; } int main() { RingBuffer *rb = create_ring_buffer(BUFFER_SIZE); push(rb, 1); push(rb, 2); push(rb, 3); printf("Pop: %d\n", pop(rb)); printf("Pop: %d\n", pop(rb)); push(rb, 4); push(rb, 5); push(rb, 6); while (!is_empty(rb)) { printf("Pop: %d\n", pop(rb)); } destroy_ring_buffer(rb); return 0; } ``` 在这个示例中,我们定义了一个RingBuffer结构体,包含了一个整型数组作为缓冲区、头指针、尾指针和缓冲区大小。我们通过create_ring_buffer函数创建缓冲区,并通过destroy_ring_buffer函数销毁缓冲区。 我们还定义了is_empty和is_full函数用于判断缓冲区是否为空或已满,以及push和pop函数用于向缓冲区中添加或取出数据。 在main函数中,我们先向缓冲区中添加了三个整数,然后取出了前两个。接着,我们又向缓冲区中添加了三个整数,并通过while循环将缓冲区中的所有数据取出并打印。最后,我们销毁了缓冲区。 这个示例只是一个简单的实现,实际的环形缓冲区可能会更加复杂。但是,这个示例可以帮助你了解如何使用C语言实现环形缓冲区。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值