整理了一周近万字讲解linux基础开发工具vim,gdb,gcc,yum等的使用

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6

 

 

文章目录

 


前言

想用linux开发一些软件等必须要会的几种开发工具是必不可少的在yum vim gcc gdb中指令繁杂的是vim和gdb这两个工具至于yum和gcc的指令就比较简单了。


 

一、yum的使用

yum是linux的软件包管理器那什么是软件包呢

软件包在Linux下安装软件, 一个通常的办法是下载到程序的源代码, 并进行编译, 得到可执行程序. 但是这样太麻烦了, 于是有些人把一些常用的软件提前编译好, 做成软件包(可以理解成windows上的安装程序)放在一个服务器上, 通过包管理器可以很方便的获取到这个编译好的软件包, 直接进行安装. 软件包和软件包管理器, 就好比 "App" 和 "应用商店" 这样的关系. yum(Yellow dog Updater, Modifified)是Linux下非常常用的一种包管理器. 主要应用在Fedora, RedHat, Centos等发行版上

注意事项关于yum的所有操作必须保证主机虚拟机网络畅通

yum工具的常用选项有

yum install   : 表示安装软件包

yum 会自动找到都有哪些软件包需要下载, 这时候敲 "y" 确认安装.
出现 "complete" 字样, 说明安装完成.
注意
安装软件时由于需要向系统目录中写入内容, 一般需要 sudo 或者切到 root 账户下才能完成.
yum安装软件只能一个装完了再装另一个. 正在yum安装一个软件的过程中, 如果再尝试用yum安装另外 一个软件, yum会报错.

f3312b1dd8374944a64dcd62cfdb8b41.png

在这里我以gdb为例由于我的linux环境中已经有了gdb调试器所以机器告诉我无需下载。 

yum list   列出所有可供安装的软件包

软件包名称: 主版本号.次版本号.源程序发行号-软件包的发行号.主机平台.cpu架构.
"x86_64" 后缀表示64位系统的安装包, "i686" 后缀表示32位系统安装包. 选择包时要和系统匹配.
"el7" 表示操作系统发行版的版本. "el7" 表示的是 centos7/redhat7. "el6" 表示 centos6/redhat6
最后一列, base 表示的是 "软件源" 的名称, 类似于 "小米应用商店", "华为应用商店" 这样的概念

5e48391adbd04c09b56a85d4bef50fd5.png

由于list显示出的包太多所以我们截取一部分。 

yum list | grep xxx  :由于list显示出的安装包太多所以我们用管道的方式只筛选出我们关注的包xxx代表包的关键字比如要查找ls那么xxx就是ls

7e7d5667690844788489814fb1a79a89.png

上图是我们以ls为例 

yum search : 搜索包含指定关键字的软件包

同样我们以ls为例

b892934cd6df479abb8ed19119f16ad0.png

yum remove : 卸载指定的软件

376589721b414e888ce3605b52b24e5c.png

以gdb为例在删除的时候会询问是否删除如果输入Y就删除了。 

yum makecache : 将服务器的软件包信息缓存到本地

yum clean all : 清除缓存中老旧的头文件和软件包

yum -y update : 升级所有包的同时也升级软件和系统内核

yum -y upgrade  只升级所有包不升级软件和系统内核软件和内核保持原样

以上就是yum的常用命令命令并不多只要多练习很快就能掌握。

二、vim的使用

由于vim的模式很多在这里我们只讲解最常用的四个模式分别是命令模式插入模式底行模式和替换模式

命令模式

vim + 文件名进入vim

刚打开vim默认就在命令模式中在命令模式中不可以直接修改代码需要输入相对应的指令才可以修改。

4c7fcbda5b594019801f9b8a578d338b.png

由于我的vim是已经配置过的所以会和大家的不一样。 

插入模式进入插入模式需要在命令模式下按i或者a或者o还有其他进入插入模式的途径就不介绍了

i : 光标不动进入插入模式

94701a9cbd2a44c58475faa0faef84de.png

按i后进入插入模式光标不变 

a:光标向后移动一个然后进入插入模式

917194b54b6d407385a2f4bd3680867b.png

 5a7af2b0299c4f53bfdf264fcedfd4d2.png

按a进入插入模式发现光标向后移了一个位置 

o:光标新起一行进入插入模式

bd2e58f4596f401faf195fb2694fbe31.png

4441a974975341a38f5f590d39fd4c92.png

按o后可以看到光标新起一行进入插入模式 

底行模式在命令模式下按shift + ; 进入底行模式

3c9fb5b0ac4645f9a5846d214941793e.png

上面的界面就是底行模式底行模式可以在底下的命令行输出指令来控制vim。

由于避免多开vim的情况所以建议大家在进入底行模式前先退回到命令模式不论在任何模式下要退回到命令模式下只需要按ESC键即可。 

替换模式在命令模式下shift + r 进入替换模式

2db01a3245864c54b036b327fc3fba78.png

替换模式顾名思义就是替换非常方便。

下面进入在vim中最实用的指令讲解

底行模式下的命令

w : 保存所修改的文件

q : 直接退出文件如果已经修改了文件使用q会提示

wq : 保存并退出文件

 强制执行与其他命令配合使用   比如  w ! 强制保存

set nu : 调出行号

c3a6c588197c4e278166f18a35cda742.png

set nonu : 取消行号

8f730f2bbcfa4480923fa8f0060dd037.png

+ 指令 跳出vim显示指令

 3ba18b52f65c4035bfcde2a8b27d19d9.png

比如上图的! ls  就是在vim中显示当前路径下的ls指令

vs + 文件名分屏使用如果没有这个文件则会创建一个文件

0240f3ab0d2a4d83b0a2383d94beecb8.png 6b789707b435477d80d2eb9256cc1f10.png

如上图在此路径下并没有test.h文件在我们使用vs命令后自动给我们创建了一个.h文件并且于刚刚的test.c文件分屏使用理论上使用vs分屏没有次数但是如果要分好几个文件的屏那么体验会非常不好。

在分屏模式下想要关闭或者修改哪个文件就要让光标在那个文件里所以移动光标的指令必不可少

ctrl + ww:在分屏模式下切换光标

5f52b7702e08448ab8899fb1a8a95835.png

b4da51b82f1b47639c891bdf310caf06.png

关闭哪个文件只需要让光标在哪个文件里然后在底行模式下用q或者wq关闭即可这个操作与单个文件一样。

接下来的所有命令都在命令模式下使用

注意vim不支持右边的小数字键盘所以输入数字在字母区的上面输入。

yy/nyy  : 复制当前行或者复制当前行在内的指定若干行

此操作需要与粘贴指令配合所以先介绍粘贴指令在一起演示

p/np : 粘贴一行或者多行相同的内容到当前光标所在行之下

f87acfc146a447ac903ae7d244f34b7a.png

当我的光标放在第9行时在键盘输入yy后然后直接输入p就将第九行的内容自动粘贴到下一行如果想要复制第九行到第13行则输入5yy就是复制五行的内容然后p即可。如果想要10行一样的int i = 10那么只需要在第九行yy一下然后输入10p那么就自动粘贴了10行。

u : 撤销刚刚的操作需要注意的是即使已经保存文件也可以撤销但是一旦退出vim则不可以再撤销之前的命令

38b3e54926df43409fc528828828922e.png

7d87a10d0bd74b18ae6debbdbdf22a24.png

ctrl + r  : 对刚刚进行的撤销进行撤销

f30e678c50df47cc81e2069e25db0a94.png

f162efd0adb746a9bd48b53728eaae65.png

dd/ndd : 对当前行或者当前行在内的n行的内容进行剪切

f5c231f21fec4fa7bc544dd5e617cb4f.png

比如我的光标在第9行然后键盘输入5dd则将第九行开始的后五行内容全删掉了 

dd + p dd是剪切内容p是复制内容所以dd+p可以实现内容的移动

d214be6284224cf1a7f474c573c83ad4.png

 

cb54627fa71147bc98472f2e5067f833.png

如图所示是使用3dd + p指令后的代码

shift + g : 将光标定位到文档最结尾

1f000a00321b4785a83c58302ad2aff1.png

 gg :将光标快速定位到文档最开始

4e67cbca4f0643eea6ab1595bdabb468.png

n + shift + g :将光标定位到第n行

shift + $实际就是$键 :将光标定位到文档行的结尾

c3f2f51a0294486d9aab97cd3a5fcc79.png

比如光标在第九行i的前面使用命令后光标到结尾

shift + ^实际就是^将光标定位到文档行的开始与$是一对

nw,nb : 按照单词为单位在行内进行前后移动n个单词w向后b向前

shift + ~ 也就是~快速将光标指向的字符进行大小写转换

nr + 要替换的字符  替换n个光标从左到右n个所在的字符

nx  行内向后删除n个字符

n shift x : 行内向前删除n个字符

h j k l :h光标向左移动 j : 光标向下移动 k:光标向上移动 L 光标向右移动

以上就是vim中常用的命令及演示。

二、gcc/g++的使用

 gcc/g++是一个编译器

gcc完成需要以下几个步骤

1.预处理头文件展开条件编译宏替换去注释等

使用 gcc –E hello.c –o hello.i    

-E 从现在开始进行程序的翻译预处理做完就停下来

gcc -E + 文件名 直接生成.i文件

gcc -E + 原来的文件名 + 自己想取的文件名最好后缀为.i因为.i是预处理后的代码文件将预处理后的代码文件写入自己命名的文件中

9f05d441f6994321b4b18cbba650a4d9.png

255d6d61cec94233835e61e66220a95a.png  

2. 编译生成汇编语言

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

实例: gcc –S hello.i –o hello.s

 -S 从现在开始进行程序的翻译当编译做完就停下来

gcc -S + 文件名形成汇编代码默认形成一个.s文件在这里注意如果刚刚我们已经已经有了预处理后的.i文件那么直接用.i文件即可如果用原来.c文件则会又进行一次预处理

gcc -S + 原来文件名 + -o + 自己命名的文件名 形成一个自己指明的汇编文件

1603db189a4942eeb64dfb822d38ad88.png

8c85f18dad904d13a14161c9b8162a0c.png 编译过程为扫描程序->语法分析->语义分析->源代码优化->代码生成器->目标代码优化

扫描程序进行语法分析从左向右从上往下扫描源程序字符识别出各个单词确定单词类型。

语法分析是根据语法规则将输入的语句构建出分析树或者语法树也就是parse tree或者syntax tree

语义分析是根据上下文分析函数返回值类型是否对应这种语义检测可以理解语法分析就是描述一个句子主谓宾是否符合规则而语义用于检测句子的意思是否是正确的

目标代码生成指的是把中间代码变换成为特定机器上的低级语言代码

3. 汇编可重定位目标二进制文件不可以被执行的bin.obj

汇编阶段是把编译阶段生成的“.s”文件转成目标文件
实例: gcc –c hello.s –o hello.o
-c :从现在开始进行文件的汇编当汇编完成后就停下来
gcc -c + 文件名默认形成一个.o文件形成二进制文件文件名可以从.s开始也可以重新开始。
gcc -c + 原来文件名 + 自己命名的文件名 将二进制文件写入自己命名的文件中
3c6c9d0d6b494274ad74d42ec00cd943.png

8d963b5b5093404f888c77cd43fb24fb.png

4.链接将我们这自己形成的.obj文件和库文件等合并形成可执行程序

7491bfd8219b4cadb50335bad268b4da.png

ldd + 链接好的文件 可以显示都链接了哪些库

4f02907d88bb410f8ff4f75575d5e8bd.png

直接gcc + 文件名会形成一个a.out可执行文件然后./a.out可以直接运行程序

f5d84f61e27747588f8e807347891e15.png

如果想形成一个自己命名的文件gcc + 文件名 -o + 自己命名的文件

e4a5c77cdd6d461590a810fa92fd9b6b.png

 gcc + 文件名 -o + 自己命名的文件-static -static :形成一个静态库

78a6fa34d91f4af6ac8885e590d10db5.png

当出现当出现cannot find -lc时需要先下载c的静态库  yum install -y libc-static

Linux系统默认已经携带了语言级别的头文件和语言对应的库
ls /usr/include/stdio.h :查看C语言头文件所在位置
静态库   libxxxxx.a      动态库   libxxxxx.so
1.库分为静态库专门让编译器对用户的程序进行静态链接的和动态库专门让编译器对用户的程序进行动态链接的
2.静态库和静态链接链接的时候如果是静态链接找到静态库拷贝静态库中的我所需要的代码到我自己的可执行程序中
3.动态库和动态链接链接的时候如果是动态链接找到动态库拷贝动态库中的我所需要的代码的地址到我自己的可执行程序中相关的位置
4.静态链接成功:我们的程序不依赖任何库自己就可以独立运行
5.动态链接成功我们的程序还是依赖动态库一旦动态库缺失我们的程序便无法运行
6.静态库因为自身拷贝的问题比较浪费空间
7.动态库因为可以做到被大家共享所以真正的实现永远在库中程序内部只有地址比较节省空间。
8.静态库VS动态库 Linux默认使用的是动态链接和动态库

 接下来讲解Linux项目自动化构建工具-make/Makefifile

会不会写makefifile从一个侧面说明了一个人是否具备完成大型工程的能力
一个工程中的源文件不计数其按类型、功能、模块分别放在若干个目录中makefifile定义了一系列的规则来指定哪些文件需要先编译哪些文件需要后编译哪些文件需要重新编译甚至于进行更复杂的功能操作
makefifile带来的好处就是——“自动化编译”一旦写好只需要一个make命令整个工程完全自动编译极大的提高了软件开发的效率。
make是一个命令工具是一个解释makefifile中指令的命令工具一般来说大多数的IDE都有这个命令比如Delphi的makeVisual C++的nmakeLinux下GNU的make。可见makefifile都成为了一种在工程方面的编译方法。
make是一条命令makefifile是一个文件两个搭配使用完成项目自动化构建。

规则makefile是一个围绕依赖关系和依赖方法构建的一个自动化编译的工具

依赖关系中
目标文件对应的依赖文件列表可以是空

.PHONY总是被执行的

比如

a29d7e00d42847f2888a3671d05d58a3.png

 在上图的makefile里test依赖test.c.  而clean后面为空说明目标文件对应的依赖文件列表可以是空

makefile文件中保存了编译器和链接器的参数选项并且描述了所有源文件之间的关系。make程序会读取makefile文件中的数据然后根据规则调用编译器汇编器链接器产生最后的输出。
makefile里主要包含了五个东西显式规则隐晦规则变量定义文件指示和注释
显式规则说明了如何生成一个或多个目标文件
make有自动推导的功能所以隐晦的规则可以让我们比较粗糙的简略的书写makefile比如源文件与目标文件之间的时间关系判断之类
在makefile中可以定义变量当makefile被执行时其中的变量都会被扩展到相应的引用位置上通常使用$(var)表示引用变量
文件指示包含在一个makefile中引用另一个makefile类似C语言的include
注释makefile中可以使用#在行首表示行注释
默认情况下make命令会在当前目录下按顺序找寻文件名为GNUmakefilemakefile,Makefile的文件找到了解释这个文件
make的执行规则是只生成所有目标对象的第一个当然make会根据语法规则递归生成第一个目标对象的所有依赖对象后再回头生成第一个目标对象生成后退出
make在执行makefile规则中根据语法规则会分析目标对象与依赖对象的时间信息判断是否在上一次生成后源文件发生了修改若发生了修改才需要重新生成
makefile中的伪对象表示对象名称并不代表真正的文件名与实际存在的同名文件没有相互关系因此伪对象不管同名目标文件是否存在都会执行对应的生成指令。伪对象的作用有两个。1.使目标对象无论如何都要重新生成。2.并不生成目标文件而是为了执行一些指令。
makefile中使用.PHONY来声明伪对象

三、git的使用

如果没有Git就先安装git命令为 yum install git

我这里使用的码云首先在码云中新建一个仓库然后复制仓库的链接然后再linux中输入命令

git clone + 仓库链接  就能将仓库克隆到本地了

204f18a0424f478284c6ea8116538c87.png

 上图是我的仓库的路径该怎么提交呢首先将你要提交的文件拷贝到这个路径中

7f68ef7623464516ba8fe921acebd411.png

然后 git add . : .的意思是将当前目录下所有没有被添加的文件添加到仓库

接下来 git commit -m "此处是提交日志 "   提交日志必须好好写这个可以查到

e6fa4b89a6f341b5a990a839d9cbff5e.png

然后git push即可在这里会有一些问题如果你是第一次提交则会出现git config --global user.email "you@example.com"和git config --global user.name "Your Name"这样的报错这时候可以将其保存粘贴下来输入你自己的名字和邮箱运行即可。

a7b9aa149b0847f1b1b4b707682dbbd5.png

e1319b9ed1114b3588933ef223116c4b.png

这个时候代码就已经提交到远端仓库了。

git log :可以查看以往提交和删除的日志

git rm + 文件名 在git中删除一个文件删除后远端仓库也没有这个文件了 

如果要在linux中把仓库删了只需要rm .git -rf  即可

四、gdb的使用

程序的发布方式有两种debug模式和release模式
Linux gcc/g++出来的二进制程序默认是release模式
要使用gdb调试必须在源代码生成二进制程序的时候, 加上 -g 选项
首先查看自己的系统是否有gdb这个软件如果没有则使用命令:
yum install -y gdb   进行安装
在这里我们就直接使用makefile让其自动编译文件了上面已经说过要使用gdb调试必须在源代码生成二进制程序的时候加上-g选项所以我们的makefile如下图
e3cc0cc0c1294d9aaeb667f36d809c13.png

后面的-std=c99是什么意思呢因为我们在.c文件中使用了新的C语言语法特性linux默认的C语言标准是不支持这个特性的所以我将其改为c99就可以正常编译了。

e52aef1ada3f4831999613639b29fda7.png

只有在c99的标准下才默认支持for循环内定义变量。

接下来我们讲解gdb的常用指令

首先 gdb + 可执行文件  开始对文件的调试注意是可执行文件而不是普通文件

76e0e7784a4e46969261e6214a11a7dd.png

当出现如上图的提示的时候即可调试。

list / L   + 行号显示文件的源代码接着上次的位置往下列每次列10行

65a1d9c628e8478b9208698f3636cbce.png

L + 1   就是从第一行开始显示

list / L  + 函数名 列出某个函数的源代码

abb3d7f04c8b45e6ba4d7e76e57bdf01.png

run / r :直接运行完整个程序

a237640d5b5c46969e715673d2159e61.png

break / b + 行数在某行上打上断点

1413f6e705ad4258947e86b8e26c3c1e.png

如图在第五行打上了断点

info b/break  : 查看断点信息 

此命令在上图中已有显示。

d + 断点编号  删除某个断点

dd0ca35971bb42d59494e0b058e49234.png

d + breakpoints  :删除全部断点

3518219deff64e81a0f9339303338115.png

disable + breakpoint + 断点编号  禁用某个断点

83a96be314f04daeb71ae88ae2367634.png

 enable + breakpoint + 断点编号  打开某个断点

970cd75064e5418183c1189c36a3059a.png

quit 或者 ctrl + d  :  退出gdb

 d9f7c7b999e64a399a25c544e97645c9.png

n/next  : 逐过程调试遇见函数不进入函数

8b475796ea7441ca8701d4408c577a94.png

在这里要说明一下gdb的每次run都会从距离main函数最近的那个断点开始如果没有打断点run一下直接就程序运行完了也就无法调试所以正确的步骤是先打断点然后run然后逐过程或者逐语句进行调试

s/step :   逐语句调试遇见函数会进入函数

58946d30ca1a4e0ea51854e40e00d649.png

 p + 变量   打印变量值

ef17646d034e46edb8c822b234c57aec.png

display + 变量  :  常显示变量

2ab5f247f03148adb30430948e7a2373.png

每一步调试都会自动把要常显示的变量打印一遍

undisplay + 常显示变量的编号   取消常显示

1a5b9e0c3be14ee4aabcc596a1083207.png

until + 行号   在函数内进行指定位置跳转执行完区间代码

84c134dd0c034b05ab6cc46dc949e13b.png

finish : 进入一个函数只执行完一个函数就停下来

acfe23ed2a94491fa657e8a76a358285.png

c : 从一个断点处直接运行到下一个断点处

e59729ed63ba4aa28e375e021634ca01.png 

set var  : 修改变量的值

d9c6f835166b416293c7617a396b5c2e.png 

以上就是在gdb中最常用的调试命令了。

 


总结

要掌握好linux这些环境基础开发工具是必须要会的学会了这些再去写代码有着事半功倍的效果在这些工具中大多数指令是需要经常使用才能记住的所以大家一定要多去练习这些指令如果有能力的话还可以自己更深入的去研究需要说明的是虽然我们在文章中讲的git指令很少很简单但实际只是让大家掌握了如何将代码提交到远程仓库git还有很多功能是非常优秀的这就需要大家自己下去慢慢学习。

 

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6
标签: linux