Linux下的进度条的实现

     说到进度条,对没错,就是我们下载的时候显示百分比的东西,而我们在windows下看到的进度条都是经过精心设计过后得到的。同样的,在linux环境下我们也是需要这种东西的,但是在Linux的环境下我们只能用符号来代替条来进行实现。啥也不多说直接贴代码,详细的我们后面再解释。

这就是我们想要实现的代码了。按照编程的思维逻辑来讲,当我们拿到这个命题的时候,首先我们需要分析一下 一个进度条需要有哪些内容,当然是一个符号和两个框,这是最粗浅的。这时候我们可以开始想一下方法,显而易见我们可以选择循环打印来实现这个问题,但是一般的打印我们无法做到刷新。这个时候我们就要引入一个新的概念就是缓存的刷新。

首先我们来看两个例子

#include<stido.h>
int main()
{
    printf("hello\n");
    sleep(10);
    return 0;
}
#include<stido.h>
int main()
{
    sleep(10);


  printf("hello"); return 0;}



这两段程序的差别就在于输出中的\n。\n是表示换行换到当前行的下一行,即光标指向下一行最开始的位置,。但是在这里因为并没有进行缓冲刷新,所以我们会发现执行结果不同,第一个函数会显示Hello然后睡眠,而下面的函数则会等待睡眠结束后进行刷新。我们再深一步研究一下这个刷新缓存的机制。

首先介绍一下Linux里面关于标准IO的几种缓冲机制:

     1.全缓冲 ,全缓冲指的是系统在填满标准IO缓冲区之后才进行实际的IO操作;注意,对于驻留在磁盘上的文件来说通常由标准IO库实施全缓冲。

     2.行缓冲,在这种情况下,标准IO在输入和输出中遇到换行符时执行IO操作;注意,当流涉及终端的时候,通常使用的行缓冲。

     3.无缓冲,无缓冲指的是标准IO库不对字符进行缓冲存储;注意,标准出错流stderr通常是无缓冲的。

printf是一个行缓冲函数,先写到缓冲区,满足条件后,才将缓冲区刷到对应文件中,刷缓冲区的条件如下:
(1)缓冲区填满;
(2)写入的字符中有‘\n’ ,'\r';
(3)调用fflush手动刷新缓冲区;
(4)调用scanf要从缓冲区中读取数据时,也会将缓冲区内的数据刷新;
   满足上面4个条件之一缓冲区就会刷新

所以在这个进度条程序中,我们选择手动刷新也就是使用这个fflush进行手动的刷新缓存区。而我们在Printf的时候也使用\r来进行行刷新。而在上面的usleep则是以微妙时间进行睡眠,因为进度条如果一下就完成了我们就不需要他了,为了更直观地显示出来,我们需要让他显示地慢一点。而ptr的设定则是为了说明我们的进度条程序是在进行中的,刷新起来就是在旋转一般。这样一来我们的进度条程序就完成了。

综上所述,进度条程序的应用还是为了使我们能够更加深入地去理解Linux中的缓存机制,对于我们Linux学习也能更进一步。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值