我试图编写一个小程序来查找打开文件流的缓冲区大小。在搜索了一下之后,我找到了__fbufsize()函数。这是我写的代码:
#include <stdio.h>
#include <stdio_ext.h>
void main() {
FILE *f;
int bufsize;
f = fopen("test.txt","wb");
if (f == NULL) {
perror("fopen failed\n");
return;
}
bufsize = __fbufsize(f);
printf("The buffer size is %d\n",bufsize);
return;
}
我将缓冲区大小设为零。关于为什么会这样,我有点困惑。默认情况下不应该缓冲流吗?如果在调用fbufsize之前将setvbuf与_IOFBF一起使用,我会得到一个非零值。
答案 0 :(得分:5)
请注意main()
的正确返回类型为int
,而不是void
。
此代码在Linux(Ubuntu 14.04衍生测试)上编译:
#include <stdio.h>
#include <stdio_ext.h>
int main(void)
{
FILE *f;
size_t bufsize;
f = fopen("test.txt", "wb");
if (f == NULL)
{
perror("fopen failed\n");
return -1;
}
bufsize = __fbufsize(f);
printf("The buffer size is %zd\n", bufsize);
putc('\n', f);
bufsize = __fbufsize(f);
printf("The buffer size is %zd\n", bufsize);
fclose(f);
return 0;
}
运行时,它会产生:
The buffer size is 0
The buffer size is 4096
根据注释中的建议,在使用文件流之前,不会设置缓冲区大小。在此之前,您可以使用setvbuf()
更改大小,因此在您尝试使用它之前,库不会设置缓冲区大小。
BUFSIZ
中定义的宏<stdio.h>
是默认缓冲区大小。找不到setvbuf()
设置的缓冲区大小没有标准方法。您需要确定正在处理的平台,以便在__fbufsize()
上作为函数进行有用的评论(尽管它似乎是GNU libc扩展:__fbufsize()
)。
应该在程序中进行许多小的改进,但它们并不是立即密切相关的。
答案 1 :(得分:0)