setbuffer

在muduo库的AppendFile类的构造函数中,会使用::setbuffer(fp_, buffer_, sizeof buffer_);将缓冲区设置为本地的buffer_,因为虽然对于全缓冲、行缓冲之类的概念也有所了解,之前还专门写了一篇博客标准IO缓冲。但是还真没有使用过这种本地的缓冲区。所以写了一个测试代码,想要测试一下该功能。

#include <stdio.h>
#include <string.h>
#include <unistd.h>
#define MAX_LINE 64*1024

char buffer[MAX_LINE];

int main(int argc, char *argv[])
{
    if (argc < 2)
    {
        printf("%s file_name\n", argv[0]);
        return 1;
    }
    const char *file_name = argv[1];
    FILE *fp = fopen(file_name, "ae");
    setbuffer(fp, buffer, sizeof(buffer));

    char str[1024];
    memset(str, 'a', sizeof(str)-1);
    str[1024-1] = '\n';
    for (int i = 0; i < 100; i++)
    {
        printf("i = %d\n", i);
        fwrite(str, 1, sizeof(str), fp);
        sleep(1);
    }

    getchar();
}

本地缓冲区是64*1024,每次写入1024,那么理论上64次写入才会刷新到文件里。测试了下,发现确实是这样。

打开两个终端,一个使用tail -f setbuffer.txt查看文件内容,另一个使用./setbuffer setbuffer.txt执行程序,等待第64次打印后,才能看到数据一次性写入了文件。

但是有一个疑惑,就是在muduo库中,LogFile类的append_unlocked接口中,会每写入checkEveryN_次日志,自动刷新。但是如果checkEveryN_是一个不小的值,而日志量不大,那岂不是很久才能把数据写入文件中。muduo库使用的buffer_就是64*1024大小的,那么有可能很久才会写满buffer_或者写入checkEveryN_条日志。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值