Ciallo~(∠・ω< )⌒☆ ~ 今天,我将和大家一起学习 linux 基础开发工具的使用~
目录
壹 Linux编辑器 - vim使用
1.1 vim的基本概念
1.2 vim正常模式命令集
1.2.1 插入模式
1.2.2 移动光标命令
1.2.3 编辑命令
1.3 vim末行模式命令集
贰 Linux编译器 - gcc/g++使用
2.1 gcc如何完成
2.2 几个小问题
2.2.1 条件编译
2.2.2 为什么要编译成汇编文件
2.2.3 动静态库是什么
2.2.4 解决sodu报错
叁 Linux项目自动化构建工具-make/Makefile
3.1 初识makefile
3.2 .PHONY
3.3 完整的依赖关系
3.4 makefile中的写法
3.4.1 第一个版本
3.4.2 第二个版本
3.4.3 最终版本
~ 完 ~
壹 Linux编辑器 - vim使用
1.1 vim的基本概念
vim主要有三种模式,分别是命令模式、插入模式和底行模式。
- 命令模式:控制屏幕光标的移动,字符、字或行的删除,移动复制某区段及进入Insert mode下,或者到 last line mode。
- 插入模式:只有在Insert mode下,才可以做文字输入,按「ESC」键可回到命令行模式。该模式是我们后面用的最频繁的编辑模式。
- 底行模式:文件保存或退出,也可以进行文件替换,找字符串,列出行号等操作。 在命令模式下,shift+: 即可进入该模式。要查看你的所有模式:打开vim,底行模式直接输入。
模式的切换:
1.2 vim正常模式命令集
★ 命令前加数字能更快的进行批量操作 ~
1.2.1 插入模式
- 按「i」 进入插入模式「insert mode」从光标当前位置开始输入文件;
- 按「a」进入插入模式后,是从目前光标所在位置的下一个位置开始输入文字;
- 按「o」进入插入模式后,是插入新的一行,从行首开始输入文字。
1.2.2 移动光标命令
- 按「h」、「j」、「k」、 「l」:控制光标左、下、上、右移一格 ~
- 按[gg]:进入到文本开始 ~
- 按[shift+g]:进入文本末端 ~
- 按「$」:移动到光标所在行的行尾 ~
- 按「^」:移动到光标所在行的行首 ~
- 按「w」:光标跳到下个单词的开头 ~
- 按「e」:光标跳到下个单词的字尾 ~
- 按「b」:光标回到上个单词的开头 ~
1.2.3 编辑命令
复制与黏贴与剪切
- 「yy」:复制光标所在行 ~
- 「p」:将缓冲区内的字符贴到光标所在位置 ~
- 「dd」:剪切并删除光标所在行 ~
- 「x」:剪切并删除光标所在位置后面的一个字符 ~
- 「X」:剪切并删除光标所在位置前面的一个字符 ~
撤销
- 「u」:撤销历史操作 ~
- 「ctrl + r」: 撤销u的操作 ~
一旦退出文件编辑,无法再进行撤销了~ 没有退出都可以撤销 ~
替换
- 「r」:替换光标所在处的字符 ~
- 「R」:【替换模式】替换光标所到之处的字符,直到按下「ESC」键为止 ~
- 「shift + ~」:小写改大写 ~
查找
- 「#」:选中单词 ~
- 「n」:批量查找 ~
批量注释
- ctrl+v 进入【V-BLOCK模式】 ~
- (n+) h j k l G 选择要注释行 ~
- shift+i 进入【插入模式】,输入第一行的 // ~
- esc退出【插入模式】 ~
- 完成 ~
1.3 vim末行模式命令集
- 「w」: 文件保存 ~
- 「q」:退出vim ~
- 「q!」:强制退出vim ~
- 「wq」:退出并保存文件 ~
- 「set nu」:列出行号 ~
- 「!command」:执行命令 ~
- 「%s/dst/src/」:批量替换 ~
- 「vs 文件」:分屏 ~
- 「ctrl+ww」:切换分屏 ~
贰 Linux编译器 - gcc/g++使用
2.1 gcc如何完成
gcc [选项] 要编译的文件 [选项] [目标文件]
1. 预处理(进行宏替换)
- 预处理功能主要包括宏定义,文件包含,条件编译,去注释等 ~
- 预处理指令是以#号开头的代码行 ~
- 选项“-E”:开始进程程序翻译,预处理完后就停下来 ~
- 选项“-o”是指目标文件,“.i”文件为已经过预处理的C原始程序 ~
-
gcc –E hello.c –o hello.i
2. 编译(生成汇编)
- 在这个阶段中,gcc 首先要检查代码的规范性、是否有语法错误等,以确定代码的实际要做的工作,在检查无误后,gcc 把代码翻译成汇编语言 ~
- 选项“-S”:开始翻译,编译完后就停下来 ~
-
gcc –S hello.i –o hello.s
3. 汇编(生成机器可识别代码)
- 汇编阶段是把编译阶段生成的“.s”文件转成目标文件 ~
- 读者在此可使用选项“-c”就可看到汇编代码已转化为“.o”的二进制目标代码了 ~
-
gcc –c hello.s –o hello.o
4. 链接(生成可执行文件或库文件)
- 在成功编译之后,就进入了链接阶段 ~
-
gcc hello.o –o hello
2.2 几个小问题
2.2.1 条件编译
命令行级别的宏定义:
gcc test.c -o test -DM
gcc test.c -o test -DM=100
预处理的本质就是修改编辑我们的文本代码~
-DM就是再文本文件中加入#define M 100这样的字符串~
条件编译的作用:
- 软件进行专业度,收费情况进行区分,使用条件编译,可以进行代码动态裁剪~
- 内核源代码也是采用条件编译进行代码裁剪~
- 开发工具,应用软件不同平台下的使用~
2.2.2 为什么要编译成汇编文件
程序的发展是从二进制->汇编语言->c语言->C++/JAVA等。每个阶段都经过了几十年的发展,c语言出现时汇编语言已经很成熟了,把c语言翻译成汇编语言再转换成二进制要比直接翻译成二进制容易得多~
每个语言的发明都要有对应的编译器使他可以翻译成汇编语言,那汇编语言怎么编译成二进制呢?首先在汇编语言出现后,先要发明一个二进制版的编译器,然后用汇编语言写一个汇编编译器,用二进制版的汇编编译器编译一下汇编写的汇编编译器,最后二进制版的就可以不要了,直接用汇编版的进行编译,这就是编译器的自举过程~
2.2.3 动静态库是什么
- 动态库:Linux (.so) windows (.dll)
- 静态库:Linux (.a) windows (.lib)
库是一套方法或者数据集,为开发提供最基本的保证(基本接口,功能,加速我们的二次开发)~
Linux下的C语言库为 libc.so 和 libc.a ,库的名字为去掉前缀lib和后缀.so/.a后剩余的。
动态库:把动态库内部实现的方法和我们自己的程序链接起来,让我们自己的程序能在库中找到方法,形成可执行程序,动态库在执行库中的方法时需要跳转到库中执行,完了再返回。
根据地址的替换来定位~
动态链接的图示:
静态链接就是把库里的实现拷贝一份到我们自己的代码中,用时调用自己这份实现。静态库只有在链接时有用,一旦形成可执行程序,就不需要静态库了~
动静态库对比:
- 动态库形成的可执行程序体积一定很小~
- 可执行程序堆静态库的依赖度小,动态库不能缺失~
- 程序运行需要加载到内存,静态链接的会在内存中出现大量的重复代码~
- 动态链接比较节省内存和磁盘资源~
ldd命令 - 显示所用库~ c程序默认动态链接
file命令 - 具体查看类型
如果想要静态链接:
静态链接的可执行文件会大很多~
C++的情况:
动态库(共享库)的本质就是把语言层面的公共代码在内存中只出现一份~
2.2.4 解决sodu报错
普通用户在sudo时可能会出现以上报错~
解决步骤:
- su -
- 输入root密码
- vim /etc/sudoers
- 找到位置加入:
- :wq! 强制退出
- ctrl+d 退出root
然后就完成辣~
叁 Linux项目自动化构建工具-make/Makefile
3.1 初识makefile
make是一条命令,makefile是一个文件,两个搭配使用,完成项目自动化构建。
makefile带来的好处就是——“自动化编译”,一旦写好,只需要一个make命令,整个工程完全自动编译,极大的提高了软件开发的效率。
- touch Makefile
- vim Makefile
第一行为依赖关系 ~
第二行为tab + 依赖方法 ~
上图为使用makefile的方法 ~
make命令扫描makefile文件的时候,从上向下扫描,默认形成第一个目标文件 ~
3.2 .PHONY
.PHONY修饰的每次编译都执行~(本质上是说忽略判断新旧问题)
而一般来说gcc编译的不建议加.PHONY修饰,如果源文件不改动,编译就不会执行~
Modify时间是作为知道bin和.c新旧的标准 ~
3.3 完整的依赖关系
3.4 makefile中的写法
测试方法:
@符号让make不回显~
3.4.1 第一个版本
基于变量版的Makefile ~(类似于宏)
BIN和SRC也可以优化掉~
3.4.2 第二个版本
如果有多个文件呢~