在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_条日志。