初见Linux:基础开发工具

前言:

这篇文章我们将讲述Linux的基本开发工具,以及讨论Linux的生态圈,最后再了解vim开发工具。

Yum:

YUM(Yellowdog Updater Modified)是一个在Linux系统中用于管理软件包的工具,特别是在基于RPM(Red Hat Package Manager)格式的发行版上,如Red Hat Enterprise Linux、CentOS和Fedora等。YUM允许用户轻松安装、更新和删除软件包,并自动处理依赖关系。

在Linux下安装软件的方法

使用包管理器进行安装--yum

如上图我们使用yum install tree 命令就下载了一个tree命令,通过执行tree命令可以像树形结构一样展示目录和目录下的文件。

总所周知,我们手机上想要下载一个应用程序就要去应用商店里下载,但本质上是去远端服务器上搜索,搜索到了才下载安装。在Linux的yum也是同理。

那么这里就会有疑惑,软件包是什么,是代码吗?那这些软件包是哪里来的?

软件包是一个包含软件程序及其相关文件和资源的集合,通常用于简化软件的安装、管理和分发。软件包可以包含可执行文件、库文件、配置文件等,也就是代码。那么软件包的由来其实是工程师上传的,那么工程师为什么要免费上传这些软件包呢?这就不得不提到生态。

生态:

生态是指生物体与其环境之间相互作用的系统,包括生物(如动物、植物、微生物)与非生物环境(如水、空气、土壤)的相互关系。那么在Linux操作系统中也同样存在这生态圈。

对于不同操作系统有着不同系统的生态圈,它们拥有者不同的社区群体,软件体系、官方文档,而操作系统仅仅只是操作系统生态圈的一部分。比如centos是属于企业使用较多,所以它针对的用户与社区论坛基本都是工程师。而这其中不乏很多大佬,他们不缺物质上的需求,并且也是希望生态圈越来越好,所以会无偿贡献许多文档,出现任何问题的解决方案,以及许多软件包。

vim开发工具:

Vim是一个高度可配置的文本编辑器,广泛用于编程和日常文本编辑。它的设计理念强调高效的键盘操作,特别适合需要频繁编辑文本的用户。

进入vim后我们可以像在VS一样编写C语言的代码,并且也能运行起来。

vim的多模式:

vim中有三种模式,第一种是命令模式(最重要),第二中为插入模式(一般用于编写代码),第三种为低行模式。默认打开的模式是命令模式。

一开始进入vim模式是命令行模式,键盘输入i就进入插入模式,想要退回命令行就按esc,如果一次没退出来就多按几次。

关于vim的快捷指令(命令行模式):

1.gg:光标定位到最开始

2.shift+g:光标定位到文件末尾

3.number(数字)+shift+g:光标定位到文件指定number行

4.shift+键盘上方的数字键4($):定位到当前行的末尾

5.shift+键盘上方的数字键6(^):定位到当前行的开头

6.h j k l :h(向左箭头) ,j(向下箭头),k(向上箭头),l(向右箭头)

这里要补充说明一下为什么明明键盘上有方向键却还是给予hjkl方向键属性。

上图是一款老式的键盘,可以看到在当时的键盘是没有上下左右键的,所以就在hjkl键位上赋予了方向键的属性,而要知道我们操作系统这些都是需要向前兼容的,所以自然而然的也保留了下来。

7.yy:复制当前行

8.p:黏贴当前行到下一行

9.number+p:重复黏贴number行

10.dd:剪切或删除

11.number+dd:删除当前行以及剩下的number-1行

12.x:命令行模式下的删除

13.number+x:命令行模式下删除numbe个数据

14.shift+·(~):在当前光标位置进行字母大小写替换,并自动移动到下一个字母

15.shift+r:表示在当前光标位置进行代码替换到这一行结束

16.u:撤销之前的操作。

17.ctrl+u:对u撤销的操作进行撤销

18.shift+zz:保存并退出vim。

19.w:让光标以单词为单位进行移动,w移动到单词词尾。

20.b:让光标移动到单词词首

底行命令(在命令模式下输入shift+:进入):

w(保存)/q(退出vim)/set nu(显示行号)/wq(保存并退出)/!+外部命令:如ls date Vim 会暂时离开编辑状态,执行该命令,然后将结果显示在 Vim 窗口中。

补充命令:

1.批量化注释:ctrl+v进入视图模式+hjkl(对光标进行任意的上下左右移动)->shitf+i+//+esc

2.批量化去注释:ctrl+v进入视图模式+hjkl+d

在Linux中展开说说文件编译

在以前的学习我们知道,一个c语言程序从编写代码到执行需要一个过程。**1.得先预处理(进行宏替换/去掉注释/展开头文件/检查语法错误),2.编译(产生汇编指令),3.汇编(形成二进制指令),4链接(生成可执行文件,在win下后缀为.exe,linux下为a.out)。**而vs是一款集成开发环境,很难观察到文件编译链接的过程。但在Linux中可以一步一步很清楚的观察到。

1.预处理

2.编译:

3.汇编

4.链接

动静态库:

动态库:

动态库也称为共享库(Shared Library),在Linux 系统中通常以 libxxx.so 的文件名形式出现,在 Windows 系统中为 xxx.dll。接下来我将以通俗易懂的图画来解释动态库的概念。

假设我是一段C语言代码,今天是周末,我有一系列任务需要完成。

首先,我的主程序(即我)开始执行。我需要列出今天的任务,并将它们按顺序执行。每个任务就是代码中的一段指令或功能,而我将它们按计划逐一完成。我们可以把这个过程看作是"函数调用",每个任务代表一个独立的功能模块。

其中,最关键的一步是"上网",这也是我唯一需要外部支持的部分。由于在学校里没有电脑,无法直接访问网络资源,因此我需要去附近的网吧(可以看作是动态库)来执行这一任务。这里的网吧是我调用的一个"外部库函数",它是动态加载的。在没有网吧的情况下,我无法完成"上网"这一任务,就像C语言中的函数调用依赖外部库一样。

上网过程:

在网吧中,我通过"调用"外部资源,完成需要的工作(例如,查找信息、玩游戏等)。这个过程类似于动态库函数被调用并执行,期间可能会有一些中断、资源管理或异常处理等步骤。玩完电脑后,我返回学校,继续执行后续任务。

返回主程序:

上网结束后,我回到主程序中,继续执行剩余的任务。这时,我已经完成了一个"外部库函数"的调用,返回到主程序,继续按预定计划进行后续工作。就像C语言中的库函数调用返回主程序后,控制权回到原先的代码执行流中一样。

通过这个比喻,我可以清楚地理解如何将日常任务与编程结构结合起来。每一个任务都有它自己的依赖条件,而有些任务则需要外部环境的支持,正如程序在运行中需要调用外部的库函数一样。而我在执行这些任务时,始终保持着"主程序"的地位,不断根据计划继续执行。

如上图我们创建了创建了一个c语言的可执行程序,通过ldd命令可以查看显示一个可执行文件或共享库依赖的共享库(动态库)列表。我们将查看到的 libc-2.17.so 这个文件。我们去掉前缀lib与后缀so,那么就变成了c-2.17这就是一个c的标准动态库。

通过file命令我们还可以很明确的看到 dynamically linked 就是动态链接。

静态库:

静态库在程序编译时就被链接到可执行文件中。当程序执行时,库的代码已经嵌入到最终的可执行文件里,不需要在运行时去加载库文件。

很显然,静态库的特点就是直接把电脑搬到学校里,也就不再需要直接去网吧里才能上网,但将电脑搬入学校里这势必会占用内存空间。

gcc默认形成的可执行程序是动态链接,如果需要静态链接则需要在链接后面加上 -static。

可以看到静态链接的程序会比动态链接内存大很多。

动静态库的优缺点:

动态库优点:共享,占用内存小,可以多个程序共用一个库,

动态库缺点:如果库文件丢失,那么只要是使用了该库文件的程序全部会崩溃。

静态库优点:不依赖外部文件,如果库丢失照样能运行。

静态库缺点:生成的可执行文件较大,浪费空间。

自动化构建-make/Makefile

认识make与Makefile:

make 是一个用于自动化构建和管理项目的工具,它特别适用于编译大型程序,能够通过读取Makefile文件中的规则来确定如何编译和链接程序。

Makefile是一个描述构建规则的文本文件,包含了项目中源代码文件之间的依赖关系以及如何从源代码生成目标文件的具体命令。make 工具通过解析 Makefile 中的规则来自动化构建过程,避免了手动编译每个文件的繁琐操作。

简单来说,make是一个指令,Makefile是一个文件。

快速上手make/Makefile:

如上图,创建了一个test.c的文件,并使用vim添加了一些代码。接着我们touch了Makefile的文件,并使用vim编辑它。保存退出后我们使用make命令后可以看到,程序自动化构建了可执行文件。

Makefile的具体语法:

第一行 mytest : test.c

我们将这一段代码成为依赖关系,就好像确认关系应该,mytest文件是依赖test.c文件的。

第二行 gcc test.c -o mytest

我们将这一段代码称之为依赖方法,就比如确认关系后,两个文件依赖这个关系做出的行为.

第四行.PHONY:clean

.PHONY是Makefile的语法,表示clean并不会真正生成一个文件,我们称之为伪目标,并且依赖方法总是被执行。

如果我们多次调用mkae程序时,并不会每次都产生可执行程序,会说明可执行程序是最新的。这么做的原因也是防止浪费资源。除非我们再次对.c文件代码进行修改时,再次make才会更新可执行程序。

通过ll命令我们发现clean文件并没有被创建,但我们使用make clean的时候会直接调用clean所依赖的方法也就是删除可执行程序。

更加具有通用性的Makefile文件:

------那么本片文章到这就结束了,感谢各位观看。

相关推荐
blessing。。12 分钟前
I2C学习
linux·单片机·嵌入式硬件·嵌入式
2202_7544215427 分钟前
生成MPSOC以及ZYNQ的启动文件BOOT.BIN的小软件
java·linux·开发语言
运维&陈同学1 小时前
【zookeeper03】消息队列与微服务之zookeeper集群部署
linux·微服务·zookeeper·云原生·消息队列·云计算·java-zookeeper
周末不下雨2 小时前
win11+ubuntu22.04双系统 | 联想 24 y7000p | ubuntu 22.04 | 把ubuntu系统装到1T的移动固态硬盘上!!!
linux·运维·ubuntu
哎呦喂-ll3 小时前
Linux进阶:环境变量
linux
Rverdoser3 小时前
Linux环境开启MongoDB的安全认证
linux·安全·mongodb
PigeonGuan3 小时前
【jupyter】linux服务器怎么使用jupyter
linux·ide·jupyter
东华果汁哥3 小时前
【linux 免密登录】快速设置kafka01、kafka02、kafka03 三台机器免密登录
linux·运维·服务器
咖喱鱼蛋4 小时前
Ubuntu安装Electron环境
linux·ubuntu·electron