Linux第一个小程序——进度条

Linux第一个小程序——进度条

  • 1. 前言
  • 2. 缓冲区概念
  • 3. \r && \n
  • 4. 进度条实现
    • 4.1 初级进度条
    • 4.2 升级进度条

1. 前言

在我们写这个小程序之前,我们要用到我们学的三个知识点

  1. gcc的使用
  2. vim的使用
  3. make/makefile的使用

除此之外还需要一些其他的知识点,但是这里重点是上面的三个知识点。所以如果由对这三个知识点不了的一定要先熟悉这三个知识点。

2. 缓冲区概念

  • 这里学一个函数和一个头文件。
    首先执行指令man 3 sleep查看第三手册手册。
    在这里插入图片描述
    在这里插入图片描述

函数sleep,头文件<unistd.h>
作用:休眠指定的秒数。
函数usleep,头文件<unistd.h>
作用:休眠指定的微秒。

  • 现在我们来写一段代码来证明这个缓冲区的存在。
    在这里插入图片描述
    在这里插入图片描述
    此时我们直接执行,是会直接显示打印出来的。
    现在我们稍作改动一下,把打印hello Linux/n中的换行\n去除再次执行。
    在这里插入图片描述

  • 我们先来分析一下。首先我们C语言有一种结构叫做顺序结构,也就是代码是从上到下依次执行的,不存在跳跃的情况,也不存先执行后面的再到过来执行前面的。也就是说上面的无论是哪一种情况都是printf先被执行然后才是sleep被执行的。那么为甚第二种情况我们在执行可执行程序的时候没有立马打印出结果来呢?而是过来3秒后也就是sleep(3)后才打印出结果来呢?理由只有一个,那就是我们在执行到printf的时候,是将printf里面的值保存起来后再去执行的sleep,而保存的地方就是我们的缓冲区。等到程序结束了,再从缓冲区中取出数据打印显示在显示屏上。而至于为什么第一种直接打印出来了呢?是因为/n有刷新缓冲区的作用,当缓冲区拿到数据并保存起来的时候,可以通过刷新缓冲区拿到数据。

3. \r && \n

大多数的人都认为回车跟换行是一回事。但是换行和回车其实是两回事。所谓换行,是执行到当前行的位置后,执行到当前位置的映射的垂直下的那个位置。而回车是执行到当前行位置后,回到开头。
之所以我们一直认为是同一回事,是因为我们通常在键盘上按回车,其实是同时执行了回车和换行,所以会另起一样并从头开始。

4. 进度条实现

4.1 初级进度条

#include <stdio.h>    
#include <unistd.h>    
#include <string.h>    
    
#define NUM 103    
int main()    
{    
    char arr[NUM];    
    arr[0] = '>';    
    int count = 0;    
    memset(arr,'\0',sizeof(arr));    
    while (count <= 100)    
    {    
        printf("%-100s\r",arr);    
        fflush(stdout);    
    
        arr[count++] = '=';    
        if (count < 100) arr[count] = '>';                                                                                                                   
        usleep(100000);    
    }    
    printf("\n");    
    
    return 0;    
}    

在这里插入图片描述
此时一个简单的进度条就完成了。

4.2 升级进度条

但是,这个只是我们模仿出来的进度条。
但是实际上的进度条是附加在其他上面的,比如下载大小上的。

  • makefile
processbar:main.c processbar.c
     gcc -o $@ $^
                                                                                                                                                          
 .PHONY:clear
 clear:
     rm main.o processbar.o processbar

  • processbar.c
char buffer[NUM] = {0};
void process_flush(double rate)
{
	int n = strlen(laber);
	static int count = 0;                                                                                                                                
	if (rate <= 1.0) buffer[0] = HEAD;
	
	fflush(stdout);
	printf("[%-100s][%.1lf%%][%c]\r",buffer,rate,laber[count % n]);
	
	buffer[(int)rate] = BODY;
	if ((int)rate + 1 < 100) buffer[(int)rate + 1] = HEAD;
	if(rate >= 100.0) printf("\n"); 
	count ++;
	count %= n;
}

  • processbar.h
#pragma once
#include <stdio.h>
#include <string.h>
#include <unistd.h>

#define NUM 103
#define HEAD '>'
#define BODY '='
typedef void(*call_func)(double);//重命名process_flush函数指针类型
                                                                                                                                                       
void process();
void process_flush(double rate);

  • main.c
#include "processbar.h"
#include <time.h>
#include <stdlib.h>
#define FILESIZE 1024*1024*1024

void downlode(call_func rq)
{    
    srand((unsigned int)time(NULL));    
    int total = FILESIZE;    
    
    while(total)    
    {    
        usleep(5000);    
        //下载速度    
        int dw_speed = rand()%1024*1024*5;    
            
        total -= dw_speed;    
        if (total <= 0) total = 0;    
    
        int download = FILESIZE - total;    
        double rate = (download * 1.0 / (FILESIZE)) * 100;    
        rq(rate);    
            
    }                                                                                                                                                        
} 
int main()    
{    
    downlode(process_flush);    
    return 0;
}

  • 执行结果
    在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/248316.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

LVS简介及LVS-NAT负载均衡群集的搭建

目录 LVS群集简介 群集的含义和应用场景 性能扩展方式 群集的分类 负载均衡&#xff08;LB&#xff09; 高可用&#xff08;HA&#xff09; 高性能运算&#xff08;HPC&#xff09; LVS的三种工作模式 NAT 地址转换 TUN IP隧道 IP Tunnel DR 直接路由 Direct Rout…

maven jar sort

1&#xff09;往常项目结构lib包排序 2&#xff09;maven的默认是没有排序的

elasticsearch|大数据|kibana的安装(https+密码)

前言&#xff1a; kibana是比较好安装的&#xff0c;但https密码就比较麻烦一些了&#xff0c;下面将就如何安装一个可在生产使用的kibana做一个简单的讲述 一&#xff0c; kibana版本和下载地址 这里我想还是强调一下&#xff0c;kibana的版本需要和elasticsearch的版本一…

ArcGIS Pro SDK文件选择对话框

文件保存对话框 // 获取默认数据库var gdbPath Project.Current.DefaultGeodatabasePath;//设置文件的保存路径SaveItemDialog saveLayerFileDialog new SaveItemDialog(){Title "Save Layer File",OverwritePrompt true,//获取或设置当同名文件已存在时是否出现…

如何用Adobe Audition 检测波形的pop和卡顿

在Adobe Audition中&#xff0c;检测卡顿和pop的方法各有不同&#xff1a; 1. **检测卡顿**&#xff1a; - 使用“诊断”面板中的“删除静音”或“标记音频”选项可以帮助识别音频中的静音段落&#xff0c;这可能表明存在卡顿。 - 配置诊断设置&#xff0c;指定静音的振…

HarmonyOS应用元服务上架

HarmonyOS应用/元服务上架 概述 当您开发、调试完HarmonyOS应用/元服务&#xff0c;就可以前往AppGallery Connect申请上架&#xff0c;华为审核通过后&#xff0c;用户即可在华为应用市场获取您的HarmonyOS应用/元服务。 HarmonyOS会通过数字证书与Profile文件等签名信息来…

LeetCode:2415. 反转二叉树的奇数层(层次遍历 Java)

目录 2415. 反转二叉树的奇数层 题目描述&#xff1a; 实现代码与解析&#xff1a; BFS 原理思路&#xff1a; 2415. 反转二叉树的奇数层 题目描述&#xff1a; 给你一棵 完美 二叉树的根节点 root &#xff0c;请你反转这棵树中每个 奇数 层的节点值。 例如&#xff0c;…

Hadoop和Spark的区别

Hadoop 表达能力有限。磁盘IO开销大&#xff0c;延迟度高。任务和任务之间的衔接涉及IO开销。前一个任务完成之前其他任务无法完成&#xff0c;难以胜任复杂、多阶段的计算任务。 Spark Spark模型是对Mapreduce模型的改进&#xff0c;可以说没有HDFS、Mapreduce就没有Spark。…

解决:AttributeError: ‘dict’ object has no attribute ‘has_key’

解决&#xff1a;AttributeError: ‘dict’ object has no attribute ‘has_key’ 文章目录 解决&#xff1a;AttributeError: dict object has no attribute has_key背景报错问题报错翻译报错位置代码报错原因解决方法方法一方法二方法三今天的分享就到此结束了 背景 在使用之…

软件供应链投毒 — NPM 恶意组件分析

聚焦源代码安全&#xff0c;网罗国内外最新资讯&#xff01; 专栏供应链安全 数字化时代&#xff0c;软件无处不在。软件如同社会中的“虚拟人”&#xff0c;已经成为支撑社会正常运转的最基本元素之一&#xff0c;软件的安全性问题也正在成为当今社会的根本性、基础性问题。 随…

redis五种数据结构特点

redis五种数据结构特点 redis-string介绍SDS内部存储数据结构三种编码方式特点总结 redis-list介绍quicklist特点总结 redis-hash特点总结 redis-set介绍 特点总结redis-zset介绍特点总结 redis使用五种数据结构&#xff0c;分别是string&#xff08;字符串&#xff09;&#x…

使用Python实现对word的批量操作

Python在平时写写小工具真是方便快捷&#xff0c;Pyhon大法好。以下所有代码都是找了好多网上的大佬分享的代码按照自己的需求改的。 调用的库为Python-docx、win32com、PyPDF2、xlwings&#xff08;操作excel&#xff09;。 因为公司的任务要对上千个word文件进行批量操作&a…

Flink+Kafka消费

引入jar <dependency><groupId>org.apache.flink</groupId><artifactId>flink-java</artifactId><version>1.8.0</version> </dependency> <dependency><groupId>org.apache.flink</groupId><artifactI…

uniapp播放 m3u8格式视频 兼容pc和移动端

支持全自动播放、设置参数 自己摸索出来的,花了一天时间,给点订阅支持下,订阅后,不懂的地方可以私聊我。 代码实现 代码实现 1.安装dplayer组件 npm i dplayer2. static/index.html下引入 hls 引入hls.min.js 可以存放在static项目hls下面<script src="/static…

如何连接到 Azure SQL 数据库(下)

在《如何连接到 Azure SQL 数据库&#xff08;上&#xff09;》中&#xff0c;我们已经了解到了以下内容↓↓↓ 开始之前&#xff1a;Azure 连接凭据和防火墙 如何检索 Azure 连接凭据如何配置服务器防火墙使用 SQL Server Management Studio 连接到 Azure使用 dbForge Studio…

最大子数组和java实现【动态规划基础练习】

12.15 最大子数组和 给你一个整数数组 nums &#xff0c;请你找出一个具有最大和的连续子数组&#xff08;子数组最少包含一个元素&#xff09;&#xff0c;返回其最大和。 子数组 是数组中的一个连续部分。 示例 1&#xff1a; 输入&#xff1a;nums [-2,1,-3,4,-1,2,1,-5,4]…

在 Windows PC 上轻松下载并安装 FFmpeg

FFmpeg 是一种开源媒体工具&#xff0c;可用于将任何视频格式转换为您需要的格式。该工具只是命令行&#xff0c;因此它没有图形、可点击的界面。如果您习惯使用常规图形 Windows 程序&#xff0c;安装 FFmpeg 一开始可能看起来很复杂&#xff0c;但不用担心&#xff0c;它;很简…

八大排序(插入排序 | 选择排序 | 冒泡排序)

在我们内存中我们一般会有一些没有顺序的数据&#xff0c;我们成为内排序&#xff0c;而今天分享八大排序的是时间复杂度为O&#xff08;N^2&#xff09;的插入排序&#xff0c;选择排序和教学意义比较强的冒泡排序。 插入排序 这是插入排序的动图&#xff0c;通过动图我们也…

01-EEA电子电器架构

1.背景 汽车正在从传统的机械装置逐步电气化&#xff0c;汽车电子电气功能不断的丰富。越来越多的电气系统和功能被集成到汽车上&#xff0c;传统的原理及线束设计已经远远不能满足。为此&#xff0c;EEA(电子电气架构)应运而生。如何设计电子电气架构&#xff0c;满足日益增长…

jenkins学习19 - pipline 构建项目生成 allure报告并发送邮箱

前言 个人其实一直的不太喜欢用邮箱发送报告&#xff0c;测试报告用邮件通知这都是五六年前的事情了&#xff0c;但有部分小伙伴依然执着于发邮件报告通知。 这里整理了下发邮箱通知的教程。 配置你的邮箱 配置邮箱这一步最繁琐&#xff0c;由于每个人使用的邮箱不一样&…