一、知识引入
在写我们的进度条之前需要先引入一下小的知识点:换行与回车,认识缓冲区,认识格式化输出
1.1 换行与回车
换行指的是跳转到下一行的同一个位置
回车指的是跳转到本行开头的位置
新起一行就是换行+回车
但是日常生活中我们见到的换行一般都是使用Enter(回车键)进行的,只是因为特殊处理的缘故
换行的符号是\n
,回车的符号是r
1.2 认识缓冲区
我们先引入一个函数sleep(time_t)
,它的作用就是休眠,单位是秒,头文件是<unistd.h>
。
接下来我们看下面两端代码
通过执行,我们发现下面的代码是先打印然后休眠;而上面的代码是先休眠然后打印的。而我们又知道C语言编译器会从上到下的扫描代码,因此输出操作一定是先读入的。那么为什么会造成这样的差异呢?这就是缓冲区的缘故了。
\n
是缓冲区的刷新标准符,用以刷新stdout。而没加\n
的输出内容被加载到了缓冲区,至于刷新缓冲区才能成功显示内容。
那么我们如何对缓冲区进行刷新呢?对语句进行回车并使用fflush()函数。
我们尝试一下发现可以了。
1.3 认识格式化输出
我们刚刚虽然打印成功输出了,但是休眠完成后发现语句被覆盖了,这又是怎么回事呢?
我们来进行下面这样一个程序:
我们通过允许发现最后的打印是" 1",我们不是从10打印到1吗?为什么后面会多出来一个0呢?
这就不得不谈到格式化输出了,其实我们也不难发现,实际上我们所看到的数字被解析成了一个个字符然后打印在屏幕上。
二、进度条小程序的编写
我们上面已经了解到了sleep()
这个函数,但是他的单位是秒,usleep()
也是休眠函数,但它的单位是微秒。
接下来我们写一个简单的进度条小程序:
但是现实中我们的这个进度条并不仅仅是计数这么简单,接下来我们模拟网络下载数据写一个进阶版的进度条: