printf 函数并不会直接将数据输出到屏幕,而是先放到缓冲区中,只有以下三种情况满
足,才会输出到屏幕。
1) 缓冲区满
2) 强制刷新缓冲区 fflush
3) 程序结束时
1.编写以下程序
1 #include<stdio.h> 2 #include<stdlib.h> 3 #include<unistd.h> 4 int main() 5 { 6 printf("hello world\n"); 7 sleep(3); 8 exit(0); 9 }
编译运行:
wys@DESKTOP-2OU3HRV:~/mycode/day08$ gcc main.c -o main wys@DESKTOP-2OU3HRV:~/mycode/day08$ ls main main.c wys@DESKTOP-2OU3HRV:~/mycode/day08$ ./main hello world wys@DESKTOP-2OU3HRV:~/mycode/day08$
我们发现屏幕上输出hello world 后,光标闪烁三秒,才出现命令输入提示行
2.编译以下程序
1 #include<stdio.h> 2 #include<stdlib.h> 3 #include<unistd.h> 4 int main() 5 { 6 printf("hello world"); 7 sleep(3); 8 exit(0); 9 }
编译运行:
wys@DESKTOP-2OU3HRV:~/mycode/day08$ gcc main.c -o main wys@DESKTOP-2OU3HRV:~/mycode/day08$ ls main main.c wys@DESKTOP-2OU3HRV:~/mycode/day08$ ./main hello worldwys@DESKTOP-2OU3HRV:~/mycode/day08$
我们看到执行可执行性程序main时,光标闪烁3秒后才输出hello world 然后屏幕出现命令输入提示行
这是因为printf函数把输出内容放入到缓冲区中,当程序结束时,才把缓冲区的内容输出打印到屏幕上!(\n 有刷新缓冲区的功能)
3.编写以下程序 强制刷新缓冲区 fflush()
1 #include<stdio.h> 2 #include<stdlib.h> 3 #include<unistd.h> 4 int main() 5 { 6 printf("hello world"); 7 fflush(stdout); 8 sleep(3); 9 exit(0); 10 }
编译运行:
wys@DESKTOP-2OU3HRV:~/mycode/day08$ gcc main.c -o main wys@DESKTOP-2OU3HRV:~/mycode/day08$ ls main main.c wys@DESKTOP-2OU3HRV:~/mycode/day08$ ./main hello worldwys@DESKTOP-2OU3HRV:~/mycode/day08$
我们发现屏幕上输出hello world 后,光标闪烁三秒,才出现命令输入提示行