vim的使用,gcc编译,静态库和共享库的生成和使用
# 学习目标:
1. 掌握vim命令模式下相关命令的使用
2. 掌握从命令模式切换到编辑模式的相关命令
3.掌握vim末行模式下相关命令的使用
4.能够说出gcc的工作流程和掌握常见参数的使用
5.熟练掌握Linux下的静态库的制作和使用
6.熟练掌握Linux下共享库的制作和使用
学习内容
1、 Vim的使用
2、 gcc编译器的使用
3、 Linux下静态库的使用
4、 Linux下动态库的使用
学习时间
2021年1月22日
1.Vim编辑器
- vim 简单介绍
vi—“virtual interface”,它在Linux上的地位仿佛Windows中的记事本一样,它可以执行编辑、删除、查找、替换、块操作等众多文本操作,而且用户可以根据自己的需要对其定制,vi是一个文本编辑程序,它不像Windows记事本中有个优美得可视化界面;使用命令对其操作。
-
vim中三种模式
命令模式,编辑模式,末行模式,三者关系如下
1.1.命令模式
命令 | 操作 |
---|---|
ZZ | 保存退出到shell命令行 |
gg=G | 代码的格式化 |
h | 光标左移 |
j | 光标下移 |
k | 光标右移 |
w | 移动一个单词的距离 |
gg | 光标移动到文件开头 |
G | 光标移动到文件末尾 |
0 | 光标移动到首行 |
$ | 光标移动到行尾 |
nG | 行跳转,例12G,跳到12行处 |
x | 删除光标后一个字符,相当于Del |
X | 删除光标前一个字符,相当于Backspace |
dw | 删除光标开始位置的字,包含光标所在字符 |
d0 | 删除光标前本行所有内容,不包含光标所在字符 |
D | 删除光标后本行所有内容,包含光标所在字符 |
dd | 删除光标所在行(其本质是剪切) |
ndd | 从光标当前行向下删除指定的函数,如15dd |
ctrl+v | 可是模式,可以移动光标选择指定内容,然后进行进一步指令 |
u | 一步一步撤销,相当于word中ctrl+z |
yy | 复制当前行 |
nyy | 复制n行,如10yy |
p | 在光标所在位置向下开辟新的一行,粘贴 |
P | 在光标所在位置向上开辟新一行,粘贴 |
剪切操作 | 按dd或者ndd删除,将删除的行数保存到剪切板中,然后按p/P就可以粘贴了 |
r | 替换当前字符 |
R | 替换当前行光标后的字符 |
/ | /xxxx,从光标所在的位置开始搜索,按n向下搜索,按N向上搜索 |
? | ?xxxx,从光标所在的位置开始搜索,按n向上搜索,按N向下搜索 |
# | 将光标移动到带搜索的字符上,然后按n向上搜索,按N向下搜索 |
shift+k | 在带搜索的字符上按shift+k或者k,可以查看相关的帮助文档 |
1.2编辑模式
从命令模式且编辑模式秩序输入如下命令:
命令 | 操作 |
---|---|
i | 在光标前插入 |
a | 在光标后插入 |
I | 在光标所在的行首插入 |
A | 在光标所在的行尾插入 |
o | 在光标所在的行下面一行创建新的一行,行首插入 |
O | 在光标所在的行上面一行创建新的一行,行首插入 |
s | 删除光标后面的字符,从光标当前位置插入 |
S | 删除光标所在当前行,行首插入 |
1.3末行模式
从命令模式切换到末行模式:输入冒号( : )
命令 | 操作 |
---|---|
q | 退出 |
q! | 强制退出 |
w | 保存修改内容 |
wq | 保存并退出 |
x | 保存并退出 |
:s/old/new/ | 光标所在的行第一个old替换为new |
:s/old/newg | 光标所在的所有old替换为new |
:m,ns/old/new/g | 将第m行至第n行之间的old全部替换为new |
:%s/old/g | 当前文件中所有old替换为new |
:1,$s/old/new/g | 当前文件的所有old体替换为new(第一行至末尾行) |
:%s/old/new/gc | 同上,但每次替换需要用户确认 |
ctrl+u | 向下翻半屏(光标向上移动) |
ctrl+d | 向上翻半屏(光标向下移动) |
ctrl+f | 向上翻一屏 |
ctrl+b | 向后翻一屏 |
sp | 当前文件水平分屏 |
vsp | 当前文件垂直分屏 |
sp 文件名 | 当前文件和另一文件水平分屏 |
vsp 文件名 | 当前文件和另一文件垂直分屏 |
ctrl+w+w | 多个窗口切换光标 |
wall/wqall/xall/qall/qall! | 保存/保存退出/保存退出/退出/强制退出 分屏窗口 |
1.4vim的配置文件
用户级别的文件配置
~./vimrc,修改用户级别的配置文件文件指挥影响当前用户,不会影响其他用户
例如在:在用户的家目录下的.vimrc 文件 添加
set nu 设置行号
set tabstop=4 设置缩进为4
set shiftwidth=4 设置gg=G缩进4个空格,默认缩进8个空格
系统级别的文件配置,不推荐!!
2.gcc 编译器
- 参数
- -v #参看gcc版本号,----version也行
- -E #生成预处理文件
- -S #生成汇编文件
- -c #只编译,生成.o文件,可重定位文件
- -I #指定同文件所在的路径
- -L #指定库文件所在的路径
- -l #指定库的名字
- -o #指定生成的目标文件的名字
- -g #包含调试信息,使用gdb调试需要添加参数-g
- -On n=0~3 #编译优化级别
- -D #编译时定义宏
3.静态库和共享库
3.1.1 什么是库
- 库是二进制文件, 是源代码文件的另一种表现形式, 是加了密的源代码; 是一些功能相近或者是相似的函数的集合体.
3.1.2 库的作用
- 提高代码的可重用性, 而且还可以提高程序的健壮性;
- 可以减少开发者的代码开发量, 缩短开发周期.
3.1.3 使用方法
- 头文件---包含了库函数的声明
- 库文件---包含了库函数的代码实现
注意: 库不能单独使用, 只能作为其他执行程序的一部分完成某些功能, 也 就是说只能被其他程序调用才能使用.
3.2.1 静态库
- 静态库可以认为是一些目标代码的集合, 是在可执行程序运行前就已经加入到执行码中, 成为执行程序的一部分. 按照习惯, 一般以.a做为文件后缀名, 静态库的命名一般分为三个部分:
- 前缀:lib
- 库名称:自定义即可, 如test
- 后缀:.a
最终的静态库的文件名为:libtest.a
- 静态库的制作:
- 将c源文件生成对应的.o文件
gcc -c fun1.c fun2.c
或者分别生成.o文件:
gcc -c fun1.c -o fun1.o
gcc -c fun2.c -o fun2.o
- 使用打包工具ar将准备好的.o文件打包为.a文件
在使用ar工具是时候需要添加参数rcs r更新、c创建、s建立索引
命令:ar rcs 静态库名 .o文件 ar rcsbtes lit1.a fun1.o fun2.o -
- 静态库的使用:
静态库制作完成之后, 需要将.a文件和头文件一定发布给用户. 假设测试文件为main.c, 静态库文件为libtest1.a, 头文件为head.h 用到的参数: - -L:指定要链接的库的所在目录
- -l:指定连接时需要的静态库,去掉前缀和后缀
- -I:指定main.c文件用到的头文件head.h所在的路径
3.2.2 共享库
- 共享库在程序编译时并不会被连接到目标代码中, 而是在程序运行是才被载入. 不同的应用程序如果调用相同的库, 那么在内存里只需要有一份该共享库的拷贝, 规避了空间浪费问题.动态库在程序运行时才被载入, 也解决了静态库对程序的更新、部署和发布会带来麻烦. 用户只需要更新动态库即可, 增量更新. 为什么需要动态库, 其实也是静态库的特点导致. 按照习惯, 一般以”.so”做为文件后缀名. 共享库的命名一般分为三个部分:
- 前缀:lib
- 库名称:自定义即可, 如test
- 后缀:.so
最终的动态库的文件名为:libtest.a
- 动态库的制作:
- 生成目标文件.o, 此时要加编译选项:-fPIC(fpic)
gcc -fpic -c fun1.c fun2.c 参数:-fpic
创建与地址无关的编译程序, 目的就是为了能够在多个应用程序间共享.
- 生成共享库, 此时要加链接器选项: -shared(指定生成动态链接库)
gcc -shared fun1.o fun2.o -o libtest2.so -
- 动态库的使用:
引用动态库编译成可执行文件(跟静态库方式一样): 用到的参数: - -L:指定要链接的库的所在目录
- -l:指定连接时需要的静态库,去掉前缀和后缀
- -I:指定main.c文件用到的头文件head.h所在的路径
gcc main.c -l./ -L./ -ltest2 -o main2
3.3 静态库和共享库的优缺点
3.1静态库
优点:
1.执行速度快, 是因为静态库已经编译到可执行文件内部了
2.移植方便, 不依赖域其他的库文件
缺点:
1.耗费内存, 是由于每一个静态库的可执行程序都会加载一次
2.部署更新麻烦, 因为静态库修改以后所有的调用到这个静态库的可执行文件都需要重新编译
3.2动态库
优点:
1.节省内存
2.部署升级更新方便, 只需替换动态库即可, 然后再重启服务.
缺点:
1.加载速度比静态库慢
2.移植性差, 需要把所有用到的动态库都移植.