在windows系统下,我们通常认为回车和换行是一个概念,但实际上,换行是指移动到下一行的当前位置,而回车则是回到当前行的开头。
我们之所以将回车和换行视为同一概念,是因为在使用n时,它同时执行了回车和换行的操作。
代码语言:C 运行次数:0
#include<stdio.h> int main(){ printf("迟来的grownn"); return 0; }
代码语言:C 运行次数:0
#include<stdio.h> int main(){ printf("迟来的grownr"); return 0; }
可以看到,n和r的效果不同,但使用r时,输出结果似乎没有显示。这是由于缓冲区的影响。
我们可以简单地理解为,输入输出操作并不是逐字符进行的(某些特殊情况除外),而是使用行缓冲区。
在行缓冲模式下,只有遇到换行符时才会执行真正的输出。因此,使用r时,输出内容会暂存在缓冲区,直到程序结束时才会清空缓冲区。
代码语言:C 运行次数:0
#include<stdio.h> int main(){ printf("迟来的grownn"); sleep(3); return 0; }
代码语言:C 运行次数:0
int main(){ printf("迟来的grown"); sleep(3); return 0; }
运行结果如下:
第一段代码先输出迟来的grown,然后休眠3秒; 第二段代码休眠3秒后,在程序结束时才输出迟来的grown。
这两段代码的区别在于是否使用了n,这也证明了行缓冲区的机制:遇到换行符时会刷新缓冲区内容(程序结束时也会刷新缓冲区内容)。
这是因为在Linux中,程序执行完毕后,光标位于行首,命令行信息会覆盖输出内容。
那么,我们能否通过一些操作来查看输出内容呢?
当然可以,我们可以使用fflush来刷新缓冲区(stdout)的内容。
代码语言:C 运行次数:0
int main(){ printf("迟来的grown"); fflush(stdout); sleep(3); return 0; }