Linux printf 函数输出问题
printf 函数并不会直接将数据输出到屏幕,而是先放到缓冲区中,只有一下三种情况满足,才会输出到屏幕。
1) 缓冲区满
2) 强制刷新缓冲区 fflush
3) 程序结束时
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 }
编译运行:
gcc main.c -o main
./main
hello world
我们发现屏幕上输出hello world 后,光标闪烁三秒,才出现命令输入提示行
编译以下程序:
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 }
编译运行:
gcc main.c -o main
./main
hello world stu@...
我们看到执行可执行性程序main时,光标闪烁3秒后才输出hello world 然后屏幕出现命令输入提示行这是因为printf函数把输出内容放入到缓冲区中,当程序结束时,才把缓冲区的内容输出打印到屏幕上!(\n 有刷新缓冲区的功能)
编写以下程序 强制刷新缓冲区 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 }
编译运行:
gcc main.c -o main
./main
hello world stu@...
我们发现屏幕上输出hello world 后,光标闪烁三秒,才出现命令输入提示行