Linux开发工具(个人使用)

Linux开发工具

    • 1.Linux yum软件包管理器
      • 1.1Linux安装程序有三种方式
      • 1.2注意事项
      • 1.3如何查看,安装,卸载软件包
        • 1.3.1查看软件包
        • 1.3.2安装软件包
        • 1.3.3卸载软件
    • 2.Linux vim编辑器
      • 2.1vim的基本操作
      • 2.2vim正常模式命令集
      • 2.3vim底行模式命令集
      • 2.4vim配置
    • 3.Linux gcc/g++编译器
      • 3.1预处理
      • 3.2编译(生成汇编)
      • 3.3汇编(生成二进制的代码)
      • 3.4链接(生成可执行文件或库文件)
      • 3.5静态库和动态库
    • 4.Linux gdb调试器
    • 5.Linux Makefile项目自动化构建工具
      • 5.1原理
    • 6.Linux程序进度条
      • 6.1缓冲区
      • 6.2倒计时程序
      • 6.3进度条
    • 7.git命令行


1.Linux yum软件包管理器

1.1Linux安装程序有三种方式

  1. 源代码安装(不推荐,问题太多,甚至编译都不成功)
  2. rpm包安装,安装的本质就是把可执行程序拷贝到指定的路径下即可(不推荐,麻烦容易出错,版本兼容问题)
  3. yum一键式安装(强烈推荐,可以类比为手机厂商的应用商店或者应用管家)

yum的相关文件会保存你所下载软件的下载路径,yum会去自己的服务器中寻找要下载的软件,而Linux服务器是由各种大厂来进行维护和报销费用,各种经过检测过合格的软件会挂在Linux的服务器上供人下载。

1.2注意事项

关于 yum 的所有操作必须保证主机(虚拟机)网络畅通!!!
可以通过 ping 指令验证是否联网

ping www.baidu.com

1.3如何查看,安装,卸载软件包

1.3.1查看软件包

通过 yum list 命令可以罗列出当前一共有哪些软件包. 由于包的数目可能非常之多, 这里我们需要使用 grep 命令只筛选出我们关注的包.

yum list | grep lrzsz
#结果:
#lrzsz.x86_64 0.12.20-36.el7 @base

软件包名称: 主版本号.次版本号.源程序发行号-软件包的发行号.主机平台.cpu架构.

“x86_64” 后缀表示64位系统的安装包, “i686” 后缀表示32位系统安装包. 选择包时要和系统匹配.

“el7” 表示操作系统发行版的版本. “el7” 表示的是 centos7/redhat7. “el6” 表示 centos6/redhat6.

最后一列, base 表示的是 “软件源” 的名称, 类似于 “小米应用商店”, “华为应用商店”

1.3.2安装软件包

通过 yum, 我们可以通过很简单的一条命令完成 gcc 的安装.

sudo yum install -y lrzsz
1.3.3卸载软件
sudo yum remove - y lrzsz

2.Linux vim编辑器

2.1vim的基本操作

在输入vim 文件名后
其他各种模式切换至正常模式

  1. 无脑ESC

正常模式切换至插入模式

  1. 输入a(光标向后移动一个字符进入插入模式)
  2. 输入i (直接进入插入模式)
  3. 输入o(光标所在行进行换行进入插入模式)

正常模式切换至底行模式
shift + ; , 其实就是输入 :(冒号)

退出vim及保存文件,在正常模式下,按下:进出底行模式
w(保存当前文件)
q(退出当前文件)
!(强制)

2.2vim正常模式命令集

移动光标

vim可以直接用键盘上的光标来上下左右移动,但正规的vim是用小写英文字母h、j、k、l,分别控制光标左、下、上、右移一格
gg:进入文本的开始
shift+g(G):移动到文章的最后
shift+4($):移动到光标所在行的行尾
shift+6(^):移动到光标所在行的行首
w:光标跳到下个单字的开头
e:光标跳到下个单字的字尾
b:光标回到上个字的开头

删除文本
x:删除光标所在位置的一个字符
X:删除光标所在位置的“前面”一个字符
dd:删除光标所在行
ndd:n为数字,从光标所在行开始删除n行

复制文本
yy:复制光标所在行到缓冲区
nyy:复制光标所在行后n行到缓冲区(包括光标所在行)
p:将缓冲区内的字符贴到光标所在位置

替换
r:替换光标所在处的字符。
R:替换光标所到之处的字符,直到ESC为止。

撤销上一次操作
u:回到上一个操作。按多次“u”可以执行多次回复。
ctrl + r: 撤销的恢复

跳到指定行
ctrl」+ g列出光标所在行的行号。
nG:表示移动光标至文章的第n行行首。

2.3vim底行模式命令集

列出行号
set nu: 输入set nu后,会在文件中的每一行前面列出行号

跳到文件中的某一行
n:直接输入数字即可

查找字符
/关键字: 如果第一次找的关键字不是您想要的,可以一直按「n」会往后寻找到您要的关键字为止。
?关键字:如果第一次找的关键字不是您想要的,可以一直按「n」会往前寻找到您要的关键字为止。

2.4vim配置

配置文件的位置在目录 /etc/ 下面,有个名为vimrc的文件
在shell中输入
curl -sLf https://gitee.com/HGtz2222/VimForCpp/raw/master/install.sh -o ./install.sh && bash ./install.sh
即可安装vim的插件进行vim的配置

3.Linux gcc/g++编译器

格式 gcc [选项] 要编译的文件 [选项] [目标文件]

3.1预处理

预处理功能主要包括宏定义,文件包含,条件编译,去注释
预处理指令是以#号开头的代码行

 gcc –E test.c –o test.i

3.2编译(生成汇编)

gcc 首先要检查代码的规范性、是否有语法错误等,以确定代码的实际要做的工作,在检查
无误后,gcc 把代码翻译成汇编语言。

gcc -S test.c -o test.s

3.3汇编(生成二进制的代码)

汇编阶段是把编译阶段生成的“.s”文件转成目标文件

gcc –c test.s –o test.o

3.4链接(生成可执行文件或库文件)

在成功编译之后,就进入了链接阶段。

gcc test.o -o test

3.5静态库和动态库

C程序头文件stdio.h中里是函数的声明,并没有定义函数的实现,包下头文件代码能跑的原因是:
系统把这些函数实现都被做到名为 libc.so.6 的库文件,在没有特别指定时,gcc 会到系统默认的搜索路径“/usr/lib”下进行查找,也就是链接到 libc.so.6 库函数中去,也就是链接的作用

静态库是指编译链接时,把库文件的代码全部加入到可执行文件中,其后缀名一般为“.a”

动态库与之相反,在编译链接时并没有把库文件的代码加入到可执行文件中,而是在程序执行时由运行时链接文件加载库,一般后缀名为“.so”

动态库优缺点
优点:形成的可执行程序体积小,节省资源
缺点:强依赖动态库,动态库没了,依赖这个库的程序就无法运行

静态库优缺点
优点:无视库,可以独立运行
缺点:体积太大,浪费资源

#C静态库安装
sudo yum install -y glibc-static
#C++静态库安装
sudo yum install -y libstdc++-static

4.Linux gdb调试器

Linux gcc/g++出来的二进制程序,默认是release模式
要使用gdb调试,必须在源代码生成二进制程序的时候, 加上 -g 选项
进入:gdb binFile
退出: ctrl + d 或 quit
调试命令:
list/l 行号:显示binFile源代码,接着上次的位置往下列,每次列10行
list/l 函数名:列出某个函数的源代码。
r或run:运行程序。
n 或 next:单条执行。
s或step:进入函数调用
break(b) 行号:在某一行设置断点
break 函数名:在某个函数开头设置断点
info break :查看断点信息。
finish:执行到当前函数返回,然后停下来等待命令
print§:打印表达式的值,通过表达式可以修改变量的值或者调用函数
p 变量:打印变量值。
set var:修改变量的值
continue(或c):从当前位置开始连续而非单步执行程序
run(或r):从开始连续而非单步执行程序
delete breakpoints:删除所有断点
delete breakpoints n:删除序号为n的断点
disable breakpoints:禁用断点
enable breakpoints:启用断点
info(或i) breakpoints:参看当前设置了哪些断点
display 变量名:跟踪查看一个变量,每次停下来都显示它的值
undisplay:取消对先前设置的那些变量的跟踪
until X行号:跳至X行
breaktrace(或bt):查看各级函数调用及参数
info(i) locals:查看当前栈帧局部变量的值
quit:退出gdb

5.Linux Makefile项目自动化构建工具

make:是一个命令
makefile:是一个在当前目录下存在的一个具有特定格式的文本文件

mytest:test.c//依赖关系
   gcc -o $@  $^//依赖方法
.PHONY:clean
clean:
   rm -f mytest    

mytest($ @)是你要的可执行程序的文件名
test.c($^)是要处理的文件
.PHONY是伪目标

5.1原理

makefile和make总是不让我们重新编译代码的
设置成伪目标后,依赖方法总是会被执行,不会被任何情况拦截
那如果没有设置成伪目标,它是如何进行拦截的呢,其实是通过时间的对比,可以做到不让有些代码进行重新编译(不让某些操作进行)
第一次的时候,一定先有源文件,才有bin文件
源文件的修改时间<bin文件的修改时间
第二/n次的时候,我们对源文件做任何修改的时候
源文件的修改时间>bin文件的修改时间

需要注意的是更改access时间,添加了次数限制
一个文件被查看的频率是非常高的,如果说每次都更改access时间,也就是访问磁盘,而Linux充满了大量的访问磁盘的IO操作,会变相减慢系统效率,所以添加了次数限制

6.Linux程序进度条

6.1缓冲区

c/C++语言,会针对标准输出,给我们提供默认的缓冲区,缓冲区并不在操作系统内,而是在内存里

#include <stdio.h>

int main()
{
    for(int i = 0; i < 10; i++)
    {
        printf("data: %d", i);
        printf("data: %d", i);
        printf("data: %d", i);
    }
    return 0;
}

这份代码在Linux的gcc编译器执行过,再运行可执行程序是没有输出的,原因在于printf会先输出到c语言的缓冲区中,这里没有对应的刷新缓冲区操作,所以是没有结果

#include <stdio.h>

int main()
{
    for(int i = 0; i < 10; i++)
    {
        printf("data: %d\n", i);
        printf("data: %d\n", i);
        printf("data: %d\n", i);
    }
    return 0;
}

加上\n就会有输出结果,因为\n是一种行刷新的策略,回车加换行
\r是只回车不换行,也不会刷新缓冲区
这里就会引出另一种刷新缓冲区的策略fflush(stdout)这里是强制刷新缓冲区
接着stdout标准输出,引出显示器其实是字符设备,显示器上显示的其实是字符,printf(“%d”,a)是格式化输出整形到显示器上去,也就是说printf格式化输出将整形转成了字符输出到显示器上

6.2倒计时程序

#include<stdio.h>  
#include<unistd.h>
int main()
{                                      
	int cnt=10;
	while(cnt>=0)
	{
		printf("%-2d\r",cnt);
		fflush(stdout);
		cnt--;
		sleep(1);
	}
	printf("\n");
	return 0;
}

6.3进度条

在这里插入图片描述

const char *str="|/-\\";

void process_v1()
{
    // version 1
    int rate=0;
    //char bar[SIZE] = {0};
    char bar[SIZE];
    memset(bar, '\0', sizeof(bar));
    int num = strlen(str);

    while(rate <= MAX_RATE)
    {
        printf("[%-100s][%d%%][%c]\r", bar, rate, str[rate%num]);
        fflush(stdout);
        usleep(STIME);
        bar[rate++] = STYLE;
    }
    printf("\n");
}

// 不能一次将进度条打印完毕,否则无法平滑的和场景结合
// 该函数,应该根据rate,自动的打一次
void process_v2(int rate)
{
    // version 2
    // TODO
    static char bar[SIZE]= {0}; 
    int num = strlen(str);
    if(rate <= MAX_RATE && rate >=0)
    {
        printf("[%-100s][%d%%][%c]\r", bar, rate, str[rate%num]);
        fflush(stdout);
        bar[rate] = STYLE;
    }
    if(rate == MAX_RATE) memset(bar, '\0', sizeof(bar));
}

void process_v3(double rate)
{
    // version 2
    static char bar[SIZE]= {0};
    static int cnt = 0;
    int num = strlen(str);
    if(rate <= MAX_RATE && rate >=0)
    {
        cnt++;
        cnt = (cnt >= num ? 0 : cnt); //cnt %= num;
        printf("加载中... [\033[31;44m%-100s\033[0m][%.1f%%][%c]\r", bar, rate, str[cnt]);
        fflush(stdout);
        if(rate < MAX_RATE)
        {
            bar[(int)rate] = STYLE_BODY; //'='
            bar[(int)rate+1] = STYLE_HEADER; //'>'
        }
        else
        {
            bar[(int)rate] = STYLE_BODY;
        }
    }
    //if(rate == MAX_RATE) memset(bar, '\0', sizeof(bar));
}

#define TARGET_SIZE 1024*1024 // 1MB
#define DSIZE 1024*10

//void download()
//{
//    int target = TARGET_SIZE;
//    int total = 0;
//
//    while(total < target)
//    {
//        usleep(STIME); // 用简单的休眠时间,模拟本轮下载花费的时间
//        total += DSIZE;
//        process_v2(total*100/target);
//    }
//    printf("\n");
//}

void download(callback_t cb)
{
    int testcnt = 100;
    int target = TARGET_SIZE;
    int total = 0;

    while(total <= target)
    {
        usleep(STIME); // 用简单的休眠时间,模拟本轮下载花费的时间
        total += DSIZE;
        double rate = total*100.0/target;
        if(rate > 50.0 && testcnt) {
            total = target/2;
            testcnt--;
        }
        cb(rate); // 回调函数
    }
    cb(MAX_RATE); // 回调函数
    printf("\n");
}


// 下载的软件
int main()
{
    download(process_v3);
    return 0;
}

7.git命令行

安装git

sudo yum install -y git

克隆仓库
创建好一个放置代码的目录
这里的 url 就是刚刚建立好的 项目 的链接

git clone [url]

三板斧

git add [文件名]
git commit . “注释日志”
git push

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

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

相关文章

imx6ull - 制作烧录SD卡

1、参考NXP官方的手册《i.MX_Linux_Users_Guide.pdf》的这一章节&#xff1a; 1、SD卡分区 提示&#xff1a;我们常用的SD卡一个扇区的大小是512字节。 先说一下i.MX6ULL使用SD卡启动时的分区情况&#xff0c;NXP官方给的镜像布局结构如下所示&#xff1a; 可以看到&#xff0c…

微服务架构-微服务治理基础

目录 一、服务治理由来 1.1 概述 1.2 微服务治理的几个维度 1.2.1 服务定义和SLA 1.2.2 服务注册中心 1.2.3 服务生命周期管理 1.2.4 服务通信和链路治理 1.2.5 服务授权和通信安全 二、服务治理的目标与愿景 2.1 服务治理的愿景 2.2 服务治理的目标 2.2.1 标准化 …

vue3使用vue3-print-nb打印

打印效果 1.下载插件 Vue2.0版本安装方法 npm install vue-print-nb --saveVue3.0版本安装方法&#xff1a; npm install vue3-print-nb --save2.main.js引入 vue2引入 import Print from vue-print-nb Vue.use(Print)vue3引入 import print from vue3-print-nb // 打印…

css :hover的使用

参考未整理 即鼠标移入类名为btn的元素时&#xff0c;她的子元素i样式发生改变 自身的样式也发生改变 &#xff0c;如果他有更多的子元素也可以这样写

LeetCode2542最大子序列的分数

题目描述 给你两个下标从 0 开始的整数数组 nums1 和 nums2 &#xff0c;两者长度都是 n &#xff0c;再给你一个正整数 k 。你必须从 nums1 中选一个长度为 k 的 子序列 对应的下标。 对于选择的下标 i0 &#xff0c;i1 &#xff0c;…&#xff0c; ik - 1 &#xff0c;你的 …

7个卖出信号出现,昂首资本立即盈利收场

在上篇文章中&#xff0c;我们和各位投资者讨论了如果使用匕首交易策略进行交易&#xff0c;但是如果只买进不卖出&#xff0c;是不是还是盈利不了&#xff1f;Anzo Capital昂首资本认为只有低买高卖才能盈利赚钱&#xff0c;只要发现盈利信号就要立即卖出盈利收场&#xff01;…

K8s中配置使用ingress

Ingress是什么 在Kubernetes中&#xff0c;Ingress是一种用于将外部流量路由到集群内部服务的API对象。它通常与Ingress控制器一起使用&#xff0c;Ingress控制器负责根据Ingress规则路由外部流量到不同的服务上。   Ingress 提供从集群外部到集群内服务的 HTTP 和 HTTPS 路由…

【算法】模拟算法——提莫攻击(easy)

题解&#xff1a;提莫攻击(模拟算法) 目录 1.题目2.题解3.参考代码4.总结 1.题目 题目链接&#xff1a;LINK 2.题解 举例&#xff1a; 3.参考代码 class Solution { public:int findPoisonedDuration(vector<int>& timeSeries, int duration) {int n timeSeri…

mysql 分区

目标 给一个表&#xff08;半年有800万&#xff09;增加分区以增加查询速度 约束 分区不能有外键否则会报错 https://blog.csdn.net/yabingshi_tech/article/details/52241034 主键 按照时间列进行分区 https://blog.csdn.net/winerpro/article/details/135736454 参看以…

CSPM.pdf

PDF转图片 归档&#xff1a;

161.二叉树:在每个树中找最大值(力扣)

代码解决 /*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode() : val(0), left(nullptr), right(nullptr) {}* TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}* Tre…

FANUC机器人保养服务包,高效又可靠!

发那科机器人作为工业生产中的重要设备&#xff0c;其保养工作至关重要。定期FANUC机械手保养不仅可以延长机器人的使用寿命&#xff0c;还能提高生产效率和质量。 法那科机器人保养步骤&#xff1a; 基本的法兰克机器人保养是维护机器人的第一步&#xff0c;正确的保养步骤还…

Nature Communications|一种超快响应的电子皮肤(柔性压力传感/界面调控/电子皮肤/柔性电子)

南方科技大学郭传飞(Chuan Fei Guo)和中国科学技术大学王柳(Liu Wang)课题组,在《Nature Communications》上发布了一篇题为“Ultrafast piezocapacitive soft pressure sensors with over 10 kHz bandwidth via bonded microstructured interfaces”的论文。论文内容如下…

万字解析线控底盘技术

文章出处&#xff1a;汽车学堂Automooc 引言 在当今这个由科技驱动的时代&#xff0c;汽车电动化、智能化已成为汽车行业的热门话题。特斯拉的自动驾驶功能、蔚来的换电模式、以及比亚迪的刀片电池技术&#xff0c;这些创新不仅引领着市场趋势&#xff0c;也推动着消费者对智…

JVM学习-字节码指令集(四)

异常处理指令 抛出异常指令 athrow指令&#xff1a;在Java程序中显示抛出异常的操作(throw语句)都是由athrow指令来实现除了throw语句显示抛出异常情况之外&#xff0c;JVM规范还规定了许多运行时异常会在其他Java虚拟机指令检测到异常状况时自动抛出&#xff0c;在之前介绍的…

你真的会用收藏夹吗?可道云teamOS收藏夹,竟能缩短多层级文件夹的路径,实现快速访问

在日常工作中&#xff0c;我们时常会面临一个让人头疼的问题&#xff1a;如何在海量的文件和资料中快速找到我们需要的那一份&#xff1f; 尤其是在团队协作中&#xff0c;每个人都在不断地上传、更新文件……导致文件目录层级复杂&#xff0c;搜索也变得繁琐。 这时候&#x…

剖析【C++】——类和对象(下篇)——超详解——小白篇

目录 1.再谈构造函数 1.1 构造函数体赋值 1.2 初始化列表 1.3 explicit 关键字 2. Static成员 2.1 概念 2.2 特性 3. 友元 3.1 友元函数 3.2 友元类 3.3总结&#xff1a; 4. 内部类 1.概念 2.特性 示例代码&#xff1a; 代码分析 3.总结 5.再次理解类和对象 …

vue-esign实现电子签名

导入依赖 pnpm install vue-esign --savesign.vue代码实现 <template><div id"app"><div class"signMask" v-if"autographStatus"><div class"sigh-btns"><button class"btn" type"info&…

mysql中子查询的语法和执行过程

大家好。我们在日常开发过程中&#xff0c;肯定都经常用到了子查询。今天我们就来聊一下mysql中子查询的一些语法以及子查询的执行过程。 一、子查询的语法 首先在开讲之前&#xff0c;我们先创建t1、t2两张表&#xff0c;并分别在表中插入三条数据&#xff0c;方便我们下面内…

269 基于matlab的四连杆机构动力学参数计算

基于matlab的四连杆机构动力学参数计算。将抽油机简化为4连杆机构&#xff0c;仿真出悬点的位移、速度、加速度、扭矩因数、游梁转角等参数&#xff0c;并绘出图形。程序已调通&#xff0c;可直接运行。 269机构动力学参数计算 位移、速度、加速度 - 小红书 (xiaohongshu.com)