VI的使用和gcc编译器
学习目标
1.掌握vim 命令模式下相关命令的使用
2.掌握从命令模式切换到编辑模式的相关命令
3.掌握 vim 末行模式下相关命令的使用
4.能够说出 gcc的工作流程和掌提常见参数的使用
5.熟练掌握 Linux 下的静态床的制作和使用
6.熟练掌握 Linux 下的共享床的制作和使用
![在这里插入图片描述](https://img-blog.csdnimg.cn/076186ef79ea4a56ad7356bc4fe3927a.png
1.vim
1.1 vim简单介绍
vi是visual interface的简称,它在 Linux 上的地位就仿佛 Windows 中的记事本一样,它可以执行编辑、删除、查找、替换、块操作等众多文本操作,而且用户可以根据自己的需要对其进行定制.vi 是一个文本编辑程序,没有莱单,只有命令.
vim 更高级一些,可以理解是 vi 的高级版本.
vim 需要自行安装,在 shell 中输入 vimtutor 命令可以查看相关的帮助文档
1.2 vim的三种模式
命令模式,文本输入模式(编辑模式),末行模式。
1.3 vim基本操作
vi/vim键盘图
1.3.1 命令模式下的基本操作
用户按下esc键后,就可以使vi进入命令模式;
当使用vi打开一个新文件,也是默认命令模式。
保存退出
zz : 保存退出
代码格式化
gg=G : 代码格式化
光标移动
h: 左移
j: 下移
k: 上移
l: 右移
w: 移动一个单词
gg: 光标移到文件开头
G: 光标移到文件末尾
0: 光标移到行首
$: 光标移到行尾
nG:行跳转,例12G,跳到12行处
删除命令
x: 删除光标后--个字符,相当于 Del
X: 删除光标前一个字符,相当于 Backspace
dw: 删除光标开始位置的字,包含光标所在字符
d0: 删除光标前本行所有内容,不包含光标所在字符
D[d$]: 删除光标后本行所有内 容,包含光标所在字符
dd: 删除光标所在行(本质其实是剪切)
ndd: 从光标当前行向下删除指定的行数,如 :15dd
v/crtl+v:使用h、j、k、1移动选择内容,然后按 d删除其中ctrl+v是列模式v为非列模式
撤销和反撤销命令
u:一步一步撤销,相当于 word 文档的 ctrl+z
ctrl-r:反撤销,相当于 word 文档的 ctrl+y
复制粘贴
yy:复制当前行
nyy:复制n行,如10yy
p:在光标所在位置向下新开辟一行,粘贴
P::在光标所在位置向上新开辟一行,粘贴
剪切操作:按dd或者ndd删除,将删除的行保存到剪贴板中,然后按p/P就可粘贴了
可视模式
v/ctrl + v:使用h,j,k,l移动选择内容;
使用d删除
使用y复制
使用p粘贴到光标的后面
使用P粘贴到光标的前面
查找
/ :从光标所在的位置开始搜索,按n 向下搜索,按 N向上搜索
? :?xxxx,从光标所在的位置开始搜索,按n向上搜索,按 N 向下搜索
# : 将光标移动到待搜索的宁符出上,然后按n 向上搜索,但 N 向下搜索
shift+k:在待搜索的字符串上按 shift+k 或者 K,可以查看相关的帮助文档
替换
r: 替换当前字符
R:替换当前行光标后的字符
1.3.2 切换到文本输入模式(编辑模式)
i : 在光标前插入
a : 在光标后插入
l : 在光标所在行的行首插入
A : 在光标所在行的行尾插入
o : 在光标所在的行的下面新创建一行,行首插入
O : 在光标所在的行的上面新创建一行,行首插入
s : 删除光标后边的字符,从光标当前位置插入
S : 删除光标所在当前行,从行首插入
按列模式插入:先按 ctrl+v 进入列模式,按 hjkl 移动选定某列,按I或者 shift+i向前插入,然后插入字符,最后按两次 esc
1.3.3 末行模式下的操作
从命令模式到末行模式,输入冒号:
保存退出
q :退出
q!:强制退出,不保存修改内容
w:保存修改内容,不退出
wq:保存并退出
x:相当于wq
替换
:s/old/new/ :光标所在行的第一个 old 替换为 new.
:s/old/new/g :光标所在行的所有 old 替换为 new.
:m, ns/old/new/g:将第 m 行至第 n 行之间的 old 全部替换成new.
:%s/old/new/g :当前文件的所有 old 替换为 new.
:1,$s/old/new/g :当前文件的所有 old 替换为 new.
:%s/old/new/gc :同上,但是每次替换需要用户确认.
快速翻屏
ctrl + u:向下翻半屏(up)-光标向上移动
ctrl + d:向上翻半屏(down)–光标向下移动
Ctrl+f:向上翻一群(front)
ctrl + b:向后翻一屏(back)
在末行模式下执行shell命令
!shell
按下两次esc可以回到命令模式
分屏操作
sR: 当前文件水平分屏
vsp:当前文件垂直分屏
sp文件名:当前文件和另一个文件水平分屏
vsp文件名:当前文件和另一个文件垂直分屏
ctrl-w-w:在多个窗口切换光标
wall/wqall/xall/qall/qall! :保存/保存退出/保存退出/退出制退出分屏窗口
1.3.4vim的配置文件
用户级别配置文件
~/.vimrc,修改用户级别的配置文件只会影响当前用户,不会影响其他的用户
例如: 在用户的家目录下的.vimrc.文件中添加
set tabstop=4----设置缩进4个空格
set nu ----设置行号
set shiftwidth=4 ---设置8=G缩进4 个空格,默认是缩进8 个空格
2.gcc编译器
2.1 gcc的工作流程
gcc编译器将c源文件到生成一个可执行程序,有四个步骤
gcc的工作流程:
1 预处理: cpp顶处理器,去掉注释,展开头文件,宏替换gcc -E test.c -o test.i
2 编译: gcc,将源代码文件编译成汇编语言代码
gcc -S test.i -o test.s
3 汇编: as,将汇编语言代码编译成了二进制文件(目标代码)
gcc -c test.s -o test.o
链接: ld,链接test.c代码中调用的库函数
gcc -o test test.o
2.2 gcc常用参数
-v 查看gcc版本号, --version也可以
-E 生成预处理文件
-S 生成汇编文件
**-c 只编译, 生成.o文件, 通常称为目标文件
-I 指定头文件所在的路径
-L 指定库文件所在的路径
-l 指定库的名字
-o 指定生成的目标文件的名字
-g 包含调试信息, 使用gdb调试需要添加-g参数**
-On n=0∼3 编译优化,n越大优化得越多
例如:下面代码片段
int a = 10;
int b = a;
int c = b;
printf("%d", c);
上面的代码可能会被编译器优化成:
int c = 10;
printf("%d", 10);
-Wall 提示更多警告信息
int a;
int b;
int c = 10;
printf(“[%d]\n”, c);
编译如下:
gcc -o test -Wall test.c
warning: unused variable ‘b’ [-Wunused-variable]
warning: unused variable ‘a’ [-Wunused-variable]
-D 编译时定义宏
test.c文件中的代码片段:
printf("MAX==[%d]\n", MAX);
编译:
gcc -o test test.c -D MAX=10
gcc -o test test.c -DMAX=10
3.静态库和共享(动态)库
什么是库
库是二进制文件, 是源代码文件的另一种表现形式, 是加了密的源代码; 是一些功能相近或者是相似的函数的集合体.
优点:
提高代码的可重用性, 而且还可以提高程序的健壮性;
可以减少开发者的代码开发量, 缩短开发周期.
库制作完成后, 如何给用户使用
头文件—包含了库函数的声明
库文件—包含了库函数的代码实现
注意: 库不能单独使用, 只能作为其他执行程序的一部分完成某些功能, 也就是说只能被其他程序调用才能使用.
3.1静态库
静态库可以认为是一些目标代码的集合, 是在可执行程序运行前就已经加入到执行码中, 成为执行程序的一部分. 按照习惯, 一般以.a做为文件后缀名.
静态库的命名一般分为三个部分:
前缀:lib
库名称:自定义即可, 如test
后缀:.a
所以最终的静态库的名字应该为:libtest.a
静态库的制作
下面以fun1.c , fun2.c和head.h三个文件为例讲述静态库的制作和使用, 其中head.h文件中有函数的声明, fun1.c和fun2.c中有函数的实现.
步骤1:将c源文件生成对应的.o文件
gcc -c fun1.c fun2.c
或者分别生成.o文件:
gcc -c fun1.c -o fun1.o
gcc -c fun2.c -o fun2.o
步骤2:使用打包工具ar将准备好的.o文件打包为.a文件
在使用ar工具是时候需要添加参数rcs
r更新、c创建、s建立索引
命令:ar rcs 静态库名 .o文件
ar rcs libtest1.a fun1.o fun2.o
静态库的使用
静态库制作完成之后, 需要将.a文件和头文件一定发布给用户.
假设测试文件为main.c, 静态库文件为libtest1.a, 头文件为head.h
用到的参数:
-L:指定要连接的库的所在目录
-l:指定链接时需要的静态库, 去掉前缀和后缀
-I: 指定main.c文件用到的头文件head.h所在的路径
gcc -o main1 main.c -L./ -ltest1 -I./
3.2动态库
共享库在程序编译时并不会被连接到目标代码中, 而是在程序运行是才被载入. 不同的应用程序如果调用相同的库, 那么在内存里只需要有一份该共享库的拷贝, 规避了空间浪费问题.动态库在程序运行时才被载入, 也解决了静态库对程序的更新、部署和发布会带来麻烦. 用户只需要更新动态库即可, 增量更新. 为什么需要动态库, 其实也是静态库的特点导致.
按照习惯, 一般以”.so”做为文件后缀名. 共享库的命名一般分为三个部分:
前缀:lib
库名称:自己定义即可, 如test
后缀:.so
所以最终的动态库的名字应该为:libtest.so
动态库的制作
1.生成目标文件.o, 此时要加编译选项:-fPIC(fpic)
gcc -fpic -c fun1.c fun2.c
参数:-fpic创建与地址无关的编译程序(pic, position independent code), 目的就是为了能够在多个应用程序间共享.
2.生成共享库, 此时要加链接器选项: -shared(指定生成动态链接库)
gcc -shared fun1.o fun2.o -o libtest2.so
动态库的使用
引用动态库编译成可执行文件(跟静态库方式一样):
用到的参数:
-L:指定要连接的库的所在目录
-l:指定链接时需要的动态库, 去掉前缀和后缀
-I: 指定main.c文件用到的头文件head.h所在的路径
gcc main.c -I./ -L./ -ltest2 -o main2
运行:./main2,发现竟然报错了.
说找不到动态库
解决办法:
永久设置, 把export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:库路径, 设置到∼/.bashrc文件中, 然后在执行下列三种办法之一:
执行. ~/.bashrc使配置文件生效(第一个.后面有一个空格)
执行source ~/.bashrc配置文件生效
退出当前终端, 然后再次登陆也可以使配置文件生效
3.3 动态库和静态库的比较
静态库的优点:
1 执行速度快, 是因为静态库已经编译到可执行文件内部了
2 移植方便, 不依赖域其他的库文件
缺点:
1 耗费内存, 是由于每一个静态库的可执行程序都会加载一次
2 部署更新麻烦, 因为静态库修改以后所有的调用到这个静态库的可执行文件都需要重新编译
动态库的优点:
1 节省内存
2 部署升级更新方便, 只需替换动态库即可, 然后再重启服务.
缺点:
1 加载速度比静态库慢
2 移植性差, 需要把所有用到的动态库都移植.
由于由静态库生成的可执行文件是把静态库加载到了其内部, 所以静态库生成的可执行文件一般会比动态库大.
总结:一般动态库用的多的多