C语言进度条的实现原理详解
目录
- \r和\n
- 行缓冲区
- 进度条
\r和\n
在程序里面,\r
和\n
分别代表什么意思?
\r:表示“回车”,即回到当前行的起始位置
\n:表示换行,即列不变,另其一个新行
行缓冲区
什么是行缓冲区?先别慌,来看代码一执行会是什么样的状态。
//代码一,mytest.c文件 # include <stdio.h> int main(void) { printf("hello linux"); sleep(1); return 0; }
现象:光标休息一秒后,打印出hello linux。
那这个现象是不是说明了,sleep先执行,printf函数后执行呢?
并不是的,在执行sleep函数之前printf函数已经被执行了,只是数据暂时存放到了行缓冲区内,没有立即刷新出来。行缓存区只有在输入和输出中遇到换行符时,缓冲区才立即刷新,然后把数据传给磁盘,执行真正的I/O操作。
有了一个认知后
//代码二,mytest.c文件 # include <stdio.h> int main(void) { printf("hello linux\r");//添加了回车 sleep(1); return 0; }
因为内容被放到了行缓冲区内,刷新缓冲区的时候,hello linux
本来是刷新出来了的,但是由于有一个\r
回车符,然后又回到了行首的位置,导致数据被覆盖了。所以休眠了一秒之后,什么也没有被显示到屏幕上。
进度条
根据上面的行缓存区的知识
总结出进度条的一个制作方法:
假设以#
作为进度条的一个显示,第一次输出#
,立即刷新出来;利用\r
回车的知识,第二次让它回到改行行首的位置,输出##
,立即刷新出来;同样的第三次回到该行行首,然后输出###
……
想法很美好,理论可以成功,开始实践……
# include <stdio.h> # include <string.h> //别忘记包含memset函数的头文件 int main(void) { char buffer[102]; //开辟一个能容纳102个字符的数组 memset(buffer, 0, sizeof(buffer));//将字符数组的每一个字节都初始化为0 int i = 0; while(i <= 100) { printf("[%-100s][%d%%]\r", buffer, i); //控制输出的格式 fflush(stdout); //立即刷新标准输出流 buffer[i++] = '#'; //把i下标的空间初始化为#之后,++i usleep(50000); //因为usleep是毫秒为单位,进度条时间可以自己控制 } printf("\n");//最后的时候换个行更加美观 return 0; }
实践成功,达到了我预期的效果,perfect!
到此这篇关于C语言进度条的实现原理详解的文章就介绍到这了,更多相关C语言进度条内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!
赞 (0)