Linux实现进度条小程序

1.预备的两个知识

usleep这个函数参数是微秒数,作用是让程序休眠对应的微秒数
1秒=1000毫秒
1毫秒=1000微秒
1微妙=1000纳秒
等等等等
因此下面的代码中的
usleep(1000000)=1秒

1.缓冲区

1.缓冲区概念的引出

首先,先让大家看两份代码,分析一下为什么出现这种情况?
在这里插入图片描述
在这里插入图片描述
请注意:这个代码运行情况是:先打印hello world,后休眠了1秒
然后我改动了一个地方,把那个’n’去掉
在这里插入图片描述
在这里插入图片描述
请注意:
这个代码运行情况是:先休眠一秒,然后打印hello world
为什么会这样呢?

2.缓冲区概念

在这里插入图片描述
注意:程序结束时会自动刷新缓冲区,把缓冲区当中数据打印出来
在这里插入图片描述
在这里插入图片描述
此时我们发现,这个代码hello world就成功地在休眠之前打印出来了

2.回车换行

1.小例子

其实,回车换行不同
什么不同

比方说:
你现在是一个高中生,你在上作文课,老师要求大家去写一篇作文
你就在作文纸上面去写,你的笔尖就相当于显示器上的光标
你的作文纸就相当于这个显示器
当你写完一段之后,你的笔尖下移:就像这样
在这里插入图片描述
光标只进行下移这一个操作,这就叫做:换行

但是真正写作文的时候,我们肯定不能只换行,我们一定要再让笔尖(光标)移动当前行的最开始处然后再去写(这里不纠结新开一个段落要空两个格),就像这样:
在这里插入图片描述
第二个操作我们叫做回车

但是呢,我们电脑上面的回车键其实完成两个工作:换行+回车
我们的旧一些的键盘上回车键就是这么标明的:
在这里插入图片描述
其实我们C语言当中的’n’也是完成了这两个任务:换行+回车
所以我们在日常生活中几乎不会深究这两个概念区别

那么C语言中有没有回车呢?
当然有啦:‘r
不过请注意: ‘r’无法自动刷新缓冲区,因此我们需要用刚才提到的fflush库函数刷新缓冲区

2.倒计时小程序

其实有了上面那两个概念之后,我们就能够写出一个倒计时程序来了
应该怎么写呢?
在这里插入图片描述
于是我们就可以写出这样的代码
在这里插入图片描述
在这里插入图片描述
我期待的是10 -> 9 -> 8 …-> 1 -> 0
结果是: 10 -> 90 -> 80 …-> 10 ->00
为什么出现这种情况呢?
其实我们的显示器是并不会给我们直接打印10这个数字
而是先打印字符’1’,然后打印字符’0’
连在一起之后我们就会认为那是10
就是说我们的这个倒计时过程其实是这样的
在这里插入图片描述
每次我们覆盖一个数据只是覆盖第一个字符’1’而已
第二个字符’0’一直都没有覆盖
那我们应该怎么办呢?
我们知道printf可以控制输出格式

printf("%2dr",count);
这样就可以把那个'0'也给覆盖掉了

因此我们可以这样改动代码
在这里插入图片描述
在这里插入图片描述
倒计时是成功了,但是它这个数字却总是右对齐的,能不能让它左对齐呢?
当然可以啦
需要加一个-即可

printf("%-2dr",count);
这样就可以左对齐了

在这里插入图片描述
在这里插入图片描述
这样我们的倒计时就大功告成了

2.基础版进度条

了解了上面那个倒计时程序之后,我们先来看一下基础版本进度条代码该怎么去设计

我们先看一下我完成之后的进度条的样子
在这里插入图片描述
首先我们先来完成那个’=‘和’>‘符号的打印
由我们刚才所写的那个倒计时程序的启发,我们可以这么来设计
在这里插入图片描述
至于这个’>‘和这个’=’我们在代码里面来控制

1.’=’的回车方式的打印

因此我们就可以写出这样的代码

#include "Processbar.h"
//VERSION 1
void Process()
{
    char tmp[NUM]={0};
    int count=0;
    while(count<=100)
    {
        printf("[%-100s]r",tmp);
        fflush(stdout);
        usleep(50000);
        tmp[count++]=BODY;
        if(count<100)//这里我们在count++之后再去修改tmp数组的下一个内容,保证这个进度条的'>'符号始终在最前方
        {
            tmp[count]=HEAD;
        }
    }
    printf("n");
}

在这里插入图片描述
这里这个main.c头文件写错了,应该是#include “Process.h
在这里插入图片描述
发现成功运行

2.百分比的打印

这个百分比的打印只需要注意一点

printf("[%-100s][%%%d]r",tmp,count);
这样就可以打印出%数字

在这里插入图片描述

3.状态提示符的打印

我们这么打印状态提示
在这里插入图片描述
于是就可以写出这样的代码
在这里插入图片描述

这里我们只需要注意这个不要忘了%4(对4取余)

还有这个’‘是C语言当中转义字符,
例如:’n’就是’n’被转义为了换行符,
我们想要’‘字符,就需要对这个转义字符再转义一次,就会得到原字符.
而且’\’这个字符大小其实是1个字符大小

然后我们运行一下
在这里插入图片描述
发现成功运行
至此,我们的这个基础版本进度实现结束
下面我们来看一下升级版本的进度条

3.升级版进度条

1.设计:进度条真实情况

在这里插入图片描述

2.模拟下载过程函数download

在这里插入图片描述
这里我们设计了一个模拟下载过程函数download
我们定义文件大小FILE_SIZE,设置了每一次下载的文件大小one_size,每次下载所需时间50ms(也就是50000微秒),
然后我们就能得出每次下载之后的剩余所需下载大小total,进而也能得到当前下载的进度rate

把所需的头文件包含到Peocessbar.h当中
在这里插入图片描述
然后我们的Processbar.c文件需要修改
在这里插入图片描述
在Process函数中,这个表示进度的count就可以直接对rate取整了,这样就不用之前那个版本当中while(count<=100)了,这也就是进度条真实情况的一种模拟

接下来我们再来看一下这个升级版进度条的样子
在这里插入图片描述
其实这两种进度条的样子是一样的,我们所改的是把第一种的while(count<=100)的循环版本改为了真实情况下的进度条的版本

也就是说我们模拟的那个download函数其实省去了process函数当中的usleep函数,并且process函数中的进度改为download函数提供

这也才是更加让这个进度条代码符合真实情况

以上就是我们的Linux实现进度条小程序(包含基础版本和模拟下载过程版本)的全部内容,希望能对大家有所帮助!

原文地址:https://blog.csdn.net/Wzs040810/article/details/134231376

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_38288.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注