printf是标准IO函数,存在行缓冲,先写到缓冲区,满足条件后,才将缓冲区刷到对应文件中,刷缓冲区的条件如下:
1 )缓冲区填满。2 )写入的字符中有‘\n’, '\r'。3) 调用fflush手动刷新缓冲区。4)....
测试代码如下:
/*
* printf 标准IO函数存在行缓冲
*/
#include <stdio.h>
#include <unistd.h> //for sleep
int main(void)
{
printf("hello\n"); //写入的字符中有‘\n’,'\r'
while(1)
{
printf("hello");
#if 0
sleep(1);
fflush(stdout);//刷新标准输出的缓冲区
#else
usleep(5000);//微秒 缓冲区满了
#endif //
}
return 0;
}