【Linux】调试和Git及进度条实现

news2024/11/15 15:43:23
这里是阿川的博客,祝您变得更强

✨ 个人主页:在线OJ的阿川
💖文章专栏:Linux入门到进阶
🌏代码仓库:


写在开头

现在您看到的是我的结论或想法但在这背后凝结了大量的思考、经验和讨论


在这里插入图片描述

在这里插入图片描述

目录

  • 1. 简易版倒计时
  • 2. 进度条实现(简易版)
  • 3. 进度条实现(调用版)
  • 4. 进度条实现(回调函数版)
  • 5. 进度条实现(颜色版)
  • 6. Git的介绍
  • 7. Gitee简介
  • 8. 调试


1. 简易版倒计时

实现一个倒计时:
拥有反斜杠/n可以立马刷新,但会自动换行
fflush 可以立马刷新且不会自动换行

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述


2. 进度条实现(简易版)

已经创建好了processBar.h、processBar.c、main.c、可执行程序processbar,如图1所示:
在这里插入图片描述

图1 文件展示
  1. vim processBar.c进入头文件,进行修改,具体如下:
// 引入运行程序、字符串、fflush的源文件
#include "processBar.h"
#include<string.h>
#include<unistd.h>
// 定义字符串常量
const char *lable="|/-\\";
// 具体实现的代码
void processbar(int speed)
{
    char bar[NUM];
    // 初始化字符数组
    memset(bar,'\0', sizeof(bar));
    int len = strlen(lable);
    int cnt = 0;
    while(cnt <= TOP)
    {
        printf("[%-100s][%d%%][%c]\r", bar, cnt, lable[cnt%len]);// 从左往右以百分号%及旋转体表现进度条
        // fflush立刻刷新缓存区输出
        fflush(stdout);
        // 考虑边界问题
        bar[cnt++] = BODY;
        if(cnt < 100) bar[cnt] = RIGHT;
        // usleep以微秒为单位进行输出
        usleep(speed);
    }
    // 换行
    printf("\n");
}


  1. vim processBar.h进入源文件,进行修改,具体如下:
#pragma once
#include <stdio.h>
// 宏定义进行封装
#define NUM 102
#define TOP 100
#define BODY '='
#define RIGHT '>'


extern void processbar(int speed);


  1. vim main.c进入主函数,进行修改,具体如下:
#include "processBar.h"
#include <unistd.h>
// 主函数表现
int main()
{
    processbar(50000);
    return 0;
}
  1. make 重新编译,再./processbar运行可执行程序,具体效果如图2所示:
    在这里插入图片描述
图2 效果图

3. 进度条实现(调用版)

如何调用进度条功能

  1. vim processBar.c进入头文件,进行修改,具体如下:
// 引入运行程序、字符串、fflush的源文件
#include "processBar.h"
#include<string.h>
#include<unistd.h>
// 定义字符串常量
const char *lable="|/-\\";
char bar[NUM];
// 将函数调用进度的占比率传入参数
void processbar(int rate)
{
    if(rate < 0 || rate > 100) return;
    int len = strlen(lable);
    printf("[%-100s][%d%%][%c]\r", bar, rate, lable[rate%len]);
    fflush(stdout);
    bar[rate++] = BODY;
    if(rate < 100) bar[rate] = RIGHT;
}
  1. vim processBar.h进入源文件,进行修改,具体如下:
#pragma once
#include <stdio.h>
// 宏定义进行封装
#define NUM 102
#define TOP 100
#define BODY '='
#define RIGHT '>'

// 更改声明
extern void processbar(int rate);

  1. vim main.c 进入主函数,进行修改,具体如下:
#include "processBar.h"
#include <unistd.h>
// 主函数表现
int main()
{
    // 设置目标变量和当前变量的值
    int total = 1000;
    int curr = 0;
    while(curr <= total)
    {
        // 换算成百分比的值
        processbar(curr*100/total);
        // 设置下载一个任务的增加进度
        curr += 10;
        // 加快速度
        usleep(50000);
    }
    // 换行
    printf("\n");
    return 0;
}


  1. make重新编译一下,./processbar再运行可执行程序,具体如图3所示:
    在这里插入图片描述
图3 效果图

4. 进度条实现(回调函数版)

  1. 只vim main.c修改主函数,其余processBar.h、processBar.c不变
#include "processBar.h"
#include <unistd.h>

// 引入函数指针类型
typedef void (*callback_t)(int);
// 模拟安装或下载进度
void download(callback_t cb)
{
    // 设置目标变量和当前变量的值
    int total = 1000;
    int curr = 0;
    while(curr <= total)
    {
        // 换算成百分比的值及加快速度
        usleep(50000);
        int rate = curr*100/total;
        // 通过回调函数,展示进度
        cb(rate);
        // 设置下载一个任务的增加进度
        curr += 10;
    }
    printf("\n");
}
int main()
{
    // 调用函数
    download(processbar);
    return 0;
}
  1. make重新编译一下,./processbar再运行可执行程序,具体如图3所示:
    在这里插入图片描述
图3 效果图

5. 进度条实现(颜色版)

C语言颜色的宏定义,大致如下

// \033表示告诉系统要进行颜色设置;[m表示要进行颜色关闭

#define NONE         "\033[m"
#define RED          "\033[0;32;31m"
#define GREEN        "\033[0;32;32m"
#define BLUE         "\033[0;32;34m"
#define CYAN         "\033[0;36m"
#define PURPLE       "\033[0;35m"
#define BROWN        "\033[0;33m"
#define YELLOW       "\033[1;33m"
#define WHITE        "\033[1;37m"
  1. vim processBar.c进入头文件,进行修改,具体如下:
// 引入运行程序、字符串、fflush的源文件
#include "processBar.h"
#include<string.h>
#include<unistd.h>
// 定义字符串常量
const char *lable="|/-\\";
char bar[NUM];
// 进行颜色宏定义
#define BLUE "\033[0;32;34m"
// [m表示颜色应用结束
#define NONE "\033[m"


// 将函数调用进度的占比率传入参数
void processbar(int rate)
{
    if(rate < 0 || rate > 100) return;
    int len = strlen(lable);
    // 将blue和none插入到[%-100s]中
    printf(BLUE"[%-100s]"NONE"[%d%%][%c]\r", bar, rate, lable[rate%len]);
    fflush(stdout);
    bar[rate++] = BODY;
    if(rate < 100) bar[rate] = RIGHT;
}

  1. make重新编译一下,./processbar再运行可执行程序,具体如图4所示:
    在这里插入图片描述
图4 效果图

6. Git的介绍

必要性:在公司中,每个编程人员必使用
定义:Git是一个具有网络功能的开源的版本控制器(将远端和本地部署为一体【版本控制器主要是处理各种各样变化的需求,只记录变化】),也可用于多人协作(将一份版本开源,大家一起协助),具体如图5所示:
在这里插入图片描述

图5 Git功能

可操作性: 操作挺多,这里无法详细的讲完,我会单独出一篇博客详细讲解,关注我,后面更新……


7. Gitee简介

定义:而国内的Gitee和国外的GitHub都是基于Git的商业化软件.
必要性:为以后找工作提前铺路,可以将每天的代码上传到该平台上且将该链接可以写在简历中,方便面试官更好的全面认识你。纵使不找工作,记录代码的习惯也是优秀的编程人员所必备的基本素质。
可操作性:大致的提一下国内的Gitee使:
1. 在初始化仓库中:

  • .gitignore:在里面的文件后缀,在推送或下载中均不上传具有相同的文件后缀的文件,具体如图7所示
  • 选择语言:初始仓库语言
  • 添加开源许可证:类似于一个合同,要遵循相应的规定

2. 在设置模板中:

  • Readme文件:类似于说明书
  • lssue和Pull Request模板文件及选择分支模型:涉及到多人协作相关

具体如图6所示
在这里插入图片描述

图6 展示图

在这里插入图片描述

图7 .gitignore具体图

各种操作指令:

  1. 先在Linux中安装git,指令如下:
yum install git
  1. git clone 仓库的完整链接:将远端仓库克隆到本地,如图8所示
  2. git add .:将当前目录下新增的内容添加到本地中,如图9所示
  3. git commit -m “提交的信息”:提交到本地并添加提交日志,如图9所示
  4. git push:推送到远端,如图10所示
  5. git log:可以查看历史信息,如图11所示
  6. git status:查看文件状态,如图12所示
    在这里插入图片描述
图8 git clone图

在这里插入图片描述

图9 add和commit图

在这里插入图片描述

图10 git push图

在这里插入图片描述

图11 git log图

在这里插入图片描述

图12 git status图

8. 调试

前提:程序发布的方式有debug模式和release模式,而调试必须在debug模式下进行,而可执行程序默认为release模式,若要改成 debug模式,需要在源代码生成二进制程序的时候加上-g选项,如图13所示:
在这里插入图片描述

图13 debug模式

指令:gdp
readelf -S 可执行程序:可读取程序的二进制信息,具体如图14所示:
在这里插入图片描述

图14 readelf模式

9. 夹带私货

若你能看到看到这篇文章且能看到这,则说明你我有缘留个关注吧,后面还会接着计算机408、底层原理、开源项目、以及数据、后端研发相关、实习、笔试/面试、秋招/春招、各种竞赛相关、简历相关、考研、学术相关……,祝你我变得更强

好的,到此为止啦,祝您变得更强
在这里插入图片描述
10.想说的话

实不相瞒,写的这篇博客写了六个小时(加上自己学习和纸质笔记,共九小时吧),很累希望大佬支持

在这里插入图片描述

道阻且长 行则将至
个人主页:在线OJ的阿川大佬的支持和鼓励,将是我成长路上最大的动力 在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

LinkedHashMap 如何实现排序

目录 一、LinkedHashMap二、排序实现三、代码片段分析 一、LinkedHashMap LinkedHashMap 是 Java 中的一个集合类&#xff0c;它是 HashMap 的一个子类&#xff0c;继承了 HashMap 的所有特性&#xff0c;并且在此基础上增加了一个双向链表来维护元素的插入顺序或者访问顺序。L…

java的内存分配和回收机制

Java 与 C之间有一堵由内存动态分配和垃圾收集技术所围成的高墙&#xff0c;墙外面的人想进去&#xff0c;墙里面的人却想出来。 概述 垃圾收集&#xff08;GC&#xff09;需要完成的三件事情&#xff1a; 哪些内存需要回收&#xff1f;什么时候回收&#xff1f;如何回收&am…

CloudXR 套件扩展 XR 工作流

NVIDIA为开发者提供了一个先进的平台&#xff0c;开发者可以在该平台上使用全新NVIDIA CloudXR 套件来创建可扩展、品牌化的定制扩展现实&#xff08;XR&#xff09;产品。 NVIDIA CloudXR 套件基于全新架构而打造&#xff0c;是扩展XR生态的重要工具。它为开发者、专业人士和…

高级 API 性能:着色器

着色器通过使您能够控制渲染过程的各个方面&#xff0c;在图形编程中发挥着关键作用。它们在 GPU 上运行&#xff0c;负责操作顶点、像素和其他数据。 常规着色器计算着色器像素渲染顶点着色器几何体、域和外壳着色器 常规着色器 这些提示适用于所有类型的着色器。 推荐 避…

[产品管理-10]:NPDP新产品开发 - 8 - 波士顿矩阵(当下与未来)在产品市场战略方面的应用

目录 一、波士顿矩阵 理论基础 产品类型划分 分析步骤 重要性 注意事项 二、波士顿矩阵的应用实例 示例背景 数据收集与准备 绘制波士顿矩阵 产品线分类 制定战略对策 一、波士顿矩阵&#xff1a;现在 VS 未来 波士顿矩阵理论&#xff0c;又称市场增长率-相对市场份…

读构建可扩展分布式系统:方法与实践04应用服务

1. 应用服务 1.1. 任何系统的核心都在于实现应用需求的特定业务逻辑 1.2. 服务是可扩展软件系统的核心 1.2.1. 它们将契约定义为一个API&#xff0c;向客户端声明它们的能力 1.3. 应用服务器高度依赖于编程语言&#xff0c;但通常都会提供多线程编程模型&#xff0c;允许服…

Ubuntu系统使用Docker部署Jupyter Notebook并实现笔记云同步

文章目录 前言1. 选择与拉取镜像2. 创建容器3. 访问Jupyter工作台4. 远程访问Jupyter工作台4.1 内网穿透工具安装4.2 创建远程连接公网地址4.3 使用固定二级子域名地址远程访问 前言 本文主要介绍如何在Ubuntu系统中使用Docker本地部署Jupyter Notebook&#xff0c;并结合cpol…

Netty(零散记录)

Netty&#xff1a; 1、Netty三种IO 2、Netty和Reactor的 1、Netty对Reactor的支持 Netty的线程模型时基于Reactor模型实现的&#xff0c;Netty对Reactor三种模式都有非常好的支持&#xff0c;并做了一定的改善&#xff0c;一般情况下&#xff0c;在服务端会采用主从架构模型…

Leetcode面试经典150题-739.每日温度

应读者私信要求&#xff0c;本题协商题目的具体内容 给定一个整数数组 temperatures &#xff0c;表示每天的温度&#xff0c;返回一个数组 answer &#xff0c;其中 answer[i] 是指对于第 i 天&#xff0c;下一个更高温度出现在几天后。如果气温在这之后都不会升高&#xff0…

计算机毕业设计 二手闲置交易系统的设计与实现 Java实战项目 附源码+文档+视频讲解

博主介绍&#xff1a;✌从事软件开发10年之余&#xff0c;专注于Java技术领域、Python人工智能及数据挖掘、小程序项目开发和Android项目开发等。CSDN、掘金、华为云、InfoQ、阿里云等平台优质作者✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精…

【目标检测数据集】厨房常见的水果蔬菜调味料数据集4910张39类VOC+YOLO格式

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;4910 标注数量(xml文件个数)&#xff1a;4910 标注数量(txt文件个数)&#xff1a;4910 标注…

SSH公私钥后门从入门到应急响应

目录 1. SSH公私钥与SSH公私钥后门介绍 1.1 SSH公私钥介绍 1.1.1 公钥和私钥的基本概念 1.1.2 SSH公私钥认证的工作原理(很重要) 1.2 SSH公私钥后门介绍 2. 如何在已拿下控制权限的主机创建后门 2.1 使用 Xshell 生成公钥与私钥 2.2 将公钥上传到被需要被植入后门的服务…

Qt_显示类控件

目录 一、QLabel 1、QLabel属性介绍 2、textFormat文本格式 3、pixmap标签图片 3.1 resizeEvent 4、QFrame边框 5、alignment文本对齐 6、wordWrap自动换行 7、indent设置缩进 8、margin设置边距 9、buddy设置伙伴 二、QLCDNumber 1、QLCDNumber属性介绍 2、实…

再次探讨最小生成树Prim算法

二次复习Prim算法时得到了一些新的启示。正常初次学算法时都特别注意代码&#xff0c;但是慢慢的发现&#xff0c;随着代码能力的增强&#xff0c;代码反而不是这么重要&#xff0c;重要的是算法的思路。既在自己的脑子中能有这个算法的图解。 下面展示一下二次学习的思路&…

秋韵虫趣.

文章目录 虫鸣概览虫坛文化蟀种纷呈中华蟋蟀宁阳蟋蟀刻点铁蟋长颚斗蟋 油葫芦棺头蟋中华灶蟋小素蟋树皮蟋蟀 花生大蟋斑腿针蟋其他鸣虫树蟋&#xff0c;又名竹蛉、邯郸梨片蟋&#xff0c;又名金钟、天蛉、绿蛣蛉、银琵琶凯纳奥蟋&#xff0c;又名石蛉&#xff0c;鳞蟋黄蛉蟋&am…

基于A2C与超启发式的航天器星载自主任务规划算法-笔记

1. Actor-Critic 模块 主要文件&#xff1a;AC.py, PolicyNet.py, ValueNet.py作用&#xff1a;该模块实现了 A2C&#xff08;Advantage Actor-Critic&#xff09;强化学习算法。其中&#xff0c;ActorCritic 类是核心&#xff0c;它同时管理策略网络&#xff08;Actor&#x…

misc合集(1)

[Week3] 这是一个压缩包 有密码&#xff0c;提示QmFzZUNURj8/Pz8/P0ZUQ2VzYUI base64解密是BaseCTF??????FTCesaB 猜测这应该是⼀个轴对称的密码 python ⽣成了密码字典&#xff0c;再通过 ARCHPR 进⾏字典爆破 lowercase abcdefghijklmnopqrstuvwxyz uppercase l…

Vue生命周期;Vue路由配置;vue网络请求;vue跨域处理

一&#xff0c;Vue生命周期 <template><div > <h1 click"changeText">{{ info }}</h1></div> </template><script> export default {name: HelloWorld,data(){return{info:"介绍组件生命周期"}},methods:{chang…

Android源码导入Android Studio

版权归作者所有&#xff0c;如有转发&#xff0c;请注明文章出处&#xff1a;https://cyrus-studio.github.io/blog/ 前言 需要先把 Android 源码编译一遍 然后执行下面指令就可以导入android源码了 关于 Android 源码编译可以参考这篇文章【LineageOS源码下载和编译&#xf…

GitLab CI_CD 从入门到实战笔记

第1章 认识GitLab CI/CD 1.3 GitLab CI/CD的几个基本概念 GitLab CI/CD由以下两部分构成。 &#xff08;1&#xff09;运行流水线的环境。它是由GitLab Runner提供的&#xff0c;这是一个由GitLab开发的开源软件包&#xff0c;要搭建GitLab CI/CD就必须安装它&#xff0c;因…