Linux 软件包管理器yum 自动化构建工具-make/makefile
Linux 工具
linux 软件包管理器 yum
把一些常用的软件提前编译好,做成软件包放在一个服务器上,通过包管理器可以很方便的获取到在这个编译好的软件包。直接进行安装。
软件包和软件包管理器就相当于 App 和应用商店这样的关系。
Linux 安装软件
- 源代码安装(不推荐)
- rpm 安装(不推荐)
- yum 安装(推荐 )
关于 rzsz
这个工具用于 windows 和远端的 Linux 机器通过 XShell 传输文件。
安装完毕之后可以通过拖拽的方式将文件上传。
-
rz
windows->linux
-
sz
linux->windows
- rzsz 的安装
sudo yum list | grep lrzsz (输出 rzsz 安装包的信息)
sudo yum install lrzsz.x86_64
如何卸载软件
- yun remove 软件名
yum remove lrzsz.x86_64 (卸载 rzsz)
vim 编辑器
文本编写,用 vim 来写代码
vim 是一个多模式的编辑器
常用模式
vim 文件名 (打开文件并编辑)
-
命令模式
命令模式也是默认模式,最开始打开某个文件时,就处于命令模式
在命令模式中,用户所有的输出都会当做命令。用于编辑命令。
- gg:光标定位到第一行
- shift+g:光标定位到最后一行
- n+shift+g:光标定位到第 n 行
- shift+6:定位光标到当前行开头
- shift+4:定位光标到当前行结尾
- w 和 b:光标以单词为单位进行行内或跨行移动
- h,j,k,l:左,下,上,右
- yy:复制光标所在行
- n+yy:包括光标所在行,复制 n 行
- p:粘贴到光标所在的下一行
- n+p:粘贴复制的内容 n 次
- u:撤销
- ctrl+r:撤销上次的撤销
- x:删除光标所在字符
- dd:剪切/也可用于删除
- n+dd:剪切 n 行
- shift + `(~):快速大小写转化
- n+r+字符:包含光标之后的 n 个字符替换为所按字符
- shift+r:进入批量替换模式,输入的字符会替换光标所在处的字符
-
插入模式
在命令模式下,按下 i 即可进入插入模式。
-
底行模式
-
wq:保存并退出
-
vs+文件名:再打开一个文件,与当前文件对比
-
ctrl+ww:切换窗口
-
set nu:显示行号
-
set nonu:隐藏行号
-
Linux 编译器 gcc/g++使用
gcc 只能编译 c 语言,g++可以编译 c 语言和 c++语言
背景知识
- 预处理(进行宏替换)
- 预处理功能主要包括宏定义,文件包含,条件编译,去注释等。
- 预处理指令是以#号开头的代码行。
- 实例: gcc –E test.c –o test.i
- 选项“-E”,该选项的作用是让 gcc 在预处理结束后停止编译过程。
- 选项“-o”是指目标文件,“.i”文件为已经过预处理的 C 原始程序。
- 编译(生成汇编)
- 实例: gcc –S test.i –o test.s
- 用户可以使用“-S”选项来进行查看,该选项只进行编译而不进行汇编,生成汇编代码。
- 汇编(生成机器可识别代码)
- 汇编阶段是把编译阶段生成的.s 文件转成目标文件
- 实例: gcc –c test.s –o test.o
- 连接(生成可执行文件或库文件)
- 在成功编译之后,就进入了链接阶段。
- 实例: gcc hello.o –o hello
gcc 如何完成
- 格式:gcc [选项] 要编译的文件 [选项] [目标文件]
如果不加目标文件,默认生成 a.out 可执行文件
自动化构建工具-make/makefile
- make 是一条命令,makefile 是一个文件,两个搭配使用,完成自动化构建。
- 一旦写好 makefile,只需要一个 make 命令,整个工程就会完全自动编译。
-
例如:
C 代码:
mycode.c 文件中:
#include <stdio.h> int main() { printf("hello Makefile!\n"); return 0; }
mytest.exe:mycode.c //依赖关系 gcc -o mytest.exe mycode.c //依赖方法(开头必须以tab开头) .PHONY:clean//总是被执行,与时间无关 clean: rm -f mytest.exe
直接输入 make,就会自动完成编译;输入 make clean 就会清理项目,删除 mytest.exe 文件
-
make 的默认执行
在 makefile 中,谁在最上面,谁就是 make 默认执行的代码。
-
当 make 一次后为什么就不能再 make 了?
因为没有必要再编译了。提高编译效率。
- 编译器如何做到的?
- 源文件的修改时间要比可执行文件要老。
- 如果我们更改了源文件,历史上有可执行文件,那么源文件的最近修改时间一定比可执行程序要新。
- 所以只需要比较,可执行文件的最近修改时间和源文件的最近修改时间,如果可执行新于源文件的修改时间(Modify),则需要重新编译,否则不需要重新编译。如果不想被限制,则在 makefile 中最上面加上.PHONY:mycode 即可。
- 编译器如何做到的?