printf 函数输出问题
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 后,光标闪烁三秒,才出现命令输入提示行