VIM

vim/vi的五种模式
 
  • 普通模式(Normal mode)

在普通模式中,用的编辑器命令,比如移动光标,删除文本等等。这也是Vim启动后的默认模式。这正好和许多新用户期待的操作方式相反(大多数编辑器默认模式为插入模式)。

在普通模式中,有很多方法可以进入插入模式。比较普通的方式是按a(append/追加)键或者i(insert/插入)键。

  • 插入模式(Insert mode)

在这个模式中,大多数按键都会向文本缓冲中插入文本。大多数新用户希望文本编辑器编辑过程中一直保持这个模式。

在插入模式中,可以按ESC键回到普通模式。

  • 可视模式(Visual mode)

这个模式与普通模式比较相似。但是移动命令会扩大高亮的文本区域。高亮区域可以是字符、行或者是一块文本。当执行一个非移动命令时,命令会被执行到这块高亮的区域上。Vim的"文本对象"也能和移动命令一样用在这个模式中。

  • 选择模式(Select mode)

这个模式和无模式编辑器的行为比较相似(Windows标准文本控件的方式)。这个模式中,可以用鼠标或者光标键高亮选择文本,不过输入任何字符的话,Vim会用这个字符替换选择的高亮文本块,并且自动进入插入模式。

  • 命令行模式(Command line mode)

在命令行模式中可以输入会被解释成并执行的文本。例如执行命令(:键),搜索(/?键)或者过滤命令(!键)。在命令执行之后,Vim返回到命令行模式之前的模式,通常是普通模式。

  • Ex模式(Ex mode)

这和命令行模式比较相似,在使用:visual命令离开Ex模式前,可以一次执行多条命令。

这其中我们常用到就是普通模式、插入模式和命令行模式,本课程也只涉及这三个常用模式的内容

 

三种常用模式的切换

vim启动进入普通模式,处于插入模式或命令行模式时只需要按Esc或者Ctrl+[(这在vim课程环境中不管用)即可进入普通模式。

普通模式中按i(插入)或a(附加)键都可以进入插入模式,

普通模式中按:进入命令行模式。

命令行模式中输入wq回车后保存并退出vim。


 

Esc进入普通模式,在该模式下使用方向键或者h,j,k,l键可以移动游标。

按键说明
h
l 右(小写L)
j
k
w 移动到下一个单词
b 移动到上一个单词

 

在普通模式下使用下面的键将进入插入模式,并可以从相应的位置开始输入

命令说明
i 在当前光标处进行编辑
I 在行首插入
A 在行末插入
a 在光标后插入编辑
o 在当前行后插入一个新行
O 在当前行前插入一个新行
cw 替换从光标所在位置后到一个单词结尾的字符

 

命令行模式下退出vim

从普通模式输入:进入命令行模式,输入wq回车,保存并退出编辑

以下为其它几种退出方式:

命令说明
:q! 强制退出,不保存
:q 退出
:wq! 强制保存并退出
:w <文件路径> 另存为
:saveas 文件路径 另存为
:x 保存并退出
:wq 保存并退出

 

普通模式下删除vim文本信息

进入普通模式,使用下列命令可以进行文本快速删除:

命令说明
x 删除游标所在的字符
X 删除游标所在前一个字符
Delete x
dd 删除整行
dw 删除一个单词(不适用中文)
d$D 删除至行尾
d^ 删除至行首
dG 删除到文档结尾处
d1G 删至文档首部

除此之外,你还可以在命令之前加上数字,表示一次删除多行,

 

 

一、vim重复命令

1.重复执行上次命令

在普通模式下.(小数点)表示重复上一次的命令操作

2.执行指定次数相同的命令

进入普通模式输入N<command>,N表示重复后面的次数

在普通模式下,你还可以使用dw或者daw(delete a word)删除一个单词,所以你可以很容易的联想到dnw(n替换为相应数字)表示删除n个单词

 

二、游标的快速跳转

普通模式下,下列命令可以让光标快速调转到指定位置,我们分别讨论快速实现行间跳转和行内跳转

1.行间跳转

命令说明
nG(n Shift+g) 游标移动到第 n 行(如果默认没有显示行号,请先进入命令模式,输入:set nu以显示行号)
gg 游标移动到到第一行
G(Shift+g) 到最后一行

小技巧:你在完成依次跳转后,可以使用Ctrl+o快速回到上一次(跳转前)光标所在位置,

 

2.行内跳转

普通模式下使用下列命令在行内按照单词为单位进行跳转

命令说明
w 到下一个单词的开头
e 到下一个单词的结尾
b 到前一个单词的开头
ge 到前一个单词的结尾
0^ 到行头
$ 到行尾
f<字母> 向后搜索<字母>并跳转到第一个匹配的位置(非常实用)
F<字母> 向前搜索<字母>并跳转到第一个匹配的位置
t<字母> 向后搜索<字母>并跳转到第一个匹配位置之前的一个字母(不常用)
T<字母> 向前搜索<字母>并跳转到第一个匹配位置之后的一个字母(不常用)

 

三、复制粘贴和剪切

1.复制及粘贴文本

  • 普通模式中使用y复制

    • 普通模式中,yy复制游标所在的整行(3yy表示复制3行)
    • 普通模式中,y^ 复制至行首,或y0。不含光标所在处字符。
    • 普通模式中,y$ 复制至行尾。含光所在处字符。
    • 普通模式中,yw 复制一个单词。
    • 普通模式中,y2w 复制两个单词。
    • 普通模式中,yG 复制至文本末。
    • 普通模式中,y1G 复制至文本开头。
  • 普通模式中使用p粘贴

    • 普通模式中,p(小写)代表粘贴至光标后(下)
    • 普通模式中,P(大写)代表粘贴至光标前(上)

 

2.剪切及粘贴

其实前面讲得dd删除命令就是剪切

ddp,就这么简单,即实现了快速交换光标所在行与它下面的行

 

一、字符的替换及撤销(Undo操作)

1.替换和撤销(Undo)命令

替换和Undo命令都是针对普通模式下的操作

命令说明
r+<待替换字母> 将游标所在字母替换为指定字母
R 连续替换,直到按下Esc
cc 替换整行,即删除游标所在行,并进入插入模式
cw 替换一个单词,即删除一个单词,并进入插入模式
C(大写) 替换游标以后至行末
~ 反转游标所在字母大小写
u{n} 撤销一次或n次操作
U(大写) 撤销当前行的所有修改
Ctrl+r redo,即撤销undo的操作

 

二、快速缩进

1.使用命令进行快速调整缩进操作

缩进操作均在普通模式下有效

  • 普通模式下输入15G,跳转到15行
  • 普通模式下输入>> 整行将向右缩进(使用,用于格式化代码超爽)
  • 普通模式下输入<< 整行向左回退
  • 普通模式下输入:进入命令行模式下对shiftwidth值进行设置可以控制缩进和回退的字符数

2.shiftwidth命令

行设置可以控制缩进和回退的字符数 获取目前的设定值

:set shiftwidth?

设置缩进为10个字符

:set shiftwidth=10

 

3.调整文本位置

命令行模式下输入:ce(center)命令使本行内容居中

命令行模式下输入:ri(right)命令使本行文本靠右

命令行模式下输入:le(left)命令使本行内容靠左

 

三、查找

1.快速查找

普通模式下输入/然后键入需要查找的字符串 按回车后就会进行查找。 /功能相同,只不过是向上而/是向下查找。 进入查找之后,输入nN可以继续查找 n表示继续查找,N反向查找

使用vim打开文件进行编辑

  • 普通模式下输入/icmp查找字符串icmp
  • 普通模式下输入n查找下一个icmp
  • 普通模式下输入?tcp向上查找字符串tcp
  • 普通模式下输入N查找上一个出现的tcp

3.高级查找

  • 普通模式下输入\*寻找游标所在处的单词
  • 普通模式下输入\#同上,但 \* 是向前(上)找,#则是向后(下)找
  • 普通模式下输入g\*\* ,但部分符合该单词即可
  • 普通模式下输入g\#\# ,但部分符合该单词即可

以上查找n,N 的继续查找命令依然可以用

 

 

一、多文件编辑

1.使用vim编辑多个文件

编辑多个文件有两种形式,一种是在进入vim前使用的参数就是多个文件。另一种就是进入vim后再编辑其他的文件。 同时创建两个新文件并编辑

$ vim 1.txt 2.txt

默认进入1.txt文件的编辑界面

  • 命令行模式下输入:n编辑2.txt文件,可以加!:n!强制切换,之前一个文件的输入没有保存,仅仅切换到另一个文件
  • 命令行模式下输入:N编辑1.txt文件,可以加!:N!强制切换,之前文件内的输入没有保存,仅仅是切换到另一个文件

2.进入vim后打开新文件

  • 命令行模式下输入:e 3.txt 打开新文件3.txt
  • 命令行模式下输入:e# 回到前一个文件
  • 命令行模式下输入:ls可以列出以前编辑过的文档
  • 命令行模式下输入:b 2.txt(或者编号)可以直接进入文件2.txt编辑
  • 命令行模式下输入:bd 2.txt(或者编号)可以删除以前编辑过的列表中的文件项目
  • 命令行模式下输入:e! 4.txt,新打开文件4.txt,放弃正在编辑的文件
  • 命令行模式下输入:f 显示正在编辑的文件名
  • 命令行模式下输入:f new.txt,改变正在编辑的文件名字为new.txt

3.恢复文件

如果因为断电等原因造成文档没有保存,可以采用恢复方式,vim -r进入文档后,输入:ewcover 1.txt来恢复

 

 

 

二、可视模式

1.可视模式命令简介

  • 在普通模式下输入v(小写),进入字符选择模式,就可以移动光标,光标走过的地方就会选取。再次按下v会后就会取消选取。
  • 在普通模式下输入Shift+v(小写),进入行选择模式,按下V之后就会把整行选取,您可以上下移动光标选更多的行,同样,再按一次Shift+v就可以取消选取。
  • 在普通模式下输入 Ctrl+v(小写),这是区域选择模式,可以进行矩形区域选择,再按一次Ctrl+v取消选取。
  • 在普通模式下输入d删除选取区域内容
  • 在普通模式下输入y复制选取区域内容

 

  • 在普通模式下9G跳转到第9行,输入Shift+v(小写V),进入可视模式进行行选择,选中5行,按下>>缩进,将5行整体缩进一个shiftwidth
  • 在普通模式下输入 Ctrl+v(小写v),进入可视模式进行矩形区域选择,选中第一列字符然后x删除整列

 

三、视窗操作

1.视窗操作简介

在命令行模式下输入:new 打开一个新的vim视窗,并进入视窗编辑一个新文件

(普通模式下输入Ctrl+w也可以,但是Ctrl+w在chrome下会与chrome关闭标签页的快捷键冲突,所以使用该快捷键你可以在IE或其它浏览器进行练习)

 

视窗操作

  • 命令行模式下输入:sp 1.txt 打开新的横向视窗来编辑1.txt
  • 命令行模式下输入:vsp 2.txt 打开新的纵向视窗来编辑1.txt
  • 普通模式下Ctrl-w s 将当前窗口分割成两个水平的窗口
  • 普通模式下Ctrl-w v 将当前窗口分割成两个垂直的窗口
  • 普通模式下Ctrl-w q 即 :q 结束分割出来的视窗。如果在新视窗中有输入需要使用强制符!即:q!
  • 普通模式下Ctrl-w o 打开一个视窗并且隐藏之前的所有视窗
  • 普通模式下Ctrl-w j 移至下面视窗
  • 普通模式下Ctrl-w k 移至上面视窗
  • 普通模式下Ctrl-w h 移至左边视窗
  • 普通模式下Ctrl-w l 移至右边视窗
  • 普通模式下Ctrl-w J 将当前视窗移至下面
  • 普通模式下Ctrl-w K 将当前视窗移至上面
  • 普通模式下Ctrl-w H 将当前视窗移至左边
  • 普通模式下Ctrl-w L 将当前视窗移至右边
  • 普通模式下Ctrl-w - 减小视窗的高度
  • 普通模式下Ctrl-w + 增加视窗的高度

 

四、文档加密

1.创建加密文档

$ vim -x file1

输入您的密码 确认密码 这样在下一次打开时,vim就会要求你输入密码

 

五、在vim执行外部命令

命令行模式中输入!可以执行外部的shell命令

  • :!ls 用于显示当前目录的内容
  • :!rm FILENAME用于删除名为 FILENAME 的文件
  • :w FILENAME可将当前 VIM 中正在编辑的文件另存为 FILENAME 文件

 

六、帮助系统(set)

1.vim中的查看帮助

  • 普通模式下按F1打开vim自己预设的帮助文档
  • 命令行模式下输入:h shiftwidth 打开名为shiftwidth的帮助文件
  • 命令行模式下输入:ver 显示版本及参数

七、功能设定 

1.vim的功能设定

可以在编辑文件的时候进行功能设定,

如命令行模式下输入:set nu(显示行数),设定值退出vim后不会保存。要永久保存配置需要修改vim配置文件。

 vim的配置文件~/.vimrc,可以打开文件进行修改,不过务必小心不要影响vim正常使用

2.获取目前的设定

  • 命令行模式下输入:set或者:se显示所有修改过的配置
  • 命令行模式下输入:set all 显示所有的设定值
  • 命令行模式下输入:set option? 显示option的设定值
  • 命令行模式下输入:set nooption 取消当期设定值

3.set功能的说明

  • 命令行模式下输入:set autoindent(ai) 设置自动缩进
  • 命令行模式下输入:set autowrite(aw) 设置自动存档,默认未打开
  • 命令行模式下输入:set background=darklight,设置背景风格
  • 命令行模式下输入:set backup(bk) 设置自动备份,默认未打开
  • 命令行模式下输入: set cindent(cin) 设置C语言风格缩进

 

 

 

 

 
 
几个操作快捷键
 
  • 大写“K”可以用来查找函数的帮助信息:查看 man page,命令模式下,将光标放在函数名上,按"K"可以直接察看 man page。
  • 几个设置

:set nu 显示行号

:set ai 自动缩行

:set ts=4 设置一个 TAB 键等于几个空格

 

 

  • 移动光标

[[ 转到上一个位于第一列的"{"

]] 转到下一个位于第一列的"{"

{ 转到上一个空行

} 转到下一个空行

gd 转到当前光标所指的局部变量的定义

 
 
emacs
 
*光标移动功能键
 
 
emacs的剪贴和黏贴
 
 
emacs的复制方式:起点:C-space / C-@(c-shift-2)
                                终点 :M-w
     黏贴C-y(指定位置)
 
 
emacs文本查找方式
 
 
emacs(1) 保存文档
            功能键:C+x C+s
                        =>对话框出现“wrote /root/workplace/editor/why”
    
            自动保存机制:hello.c =>#hello.c#
 
           (2) 退出文档:
 
                    功能键:“C+x C+c
 
 
在emacs中手动选择各种模式:(1)M-x (2)输入模式名称
 
                         快捷键M- :产生一条右缩进的注释    
     
                         高亮选择某段文本:操作“C-c C-c”=>注释该段文字
 
 
 
 
 
gcc
 

gcc 支持编译的一些源文件后缀名

后缀源文件
.c C语言源文件
.C .cc .cxx C++源文件
.m Object-C源文件
.i 经过预处理后的C源文件
.ii 经过预处理后的C++源文件
.s .S 汇编语言源文件
.h 预处理文件(头文件)
.o 目标文件
.a 存档文件
 
 
gcc的编译代码过程
 
 
 
  • 预处理:gcc –E hello.c –o hello.i;                          gcc –E调用cpp                                 (处理头文件与宏定义)
  • 编 译:gcc –S hello.i –o hello.s;                            gcc –S调用ccl                                   (代码规范性检查,产生汇编代码)
  • 汇 编:gcc –c hello.s –o hello.o;                           gcc -c 调用as                                    (转变为目标文件)
  • 链 接:gcc hello.o –o hello ;                                 gcc -o 调用ld                                    (成为可执行文件,数据库概念)
 
=>./hello(./当前目录)
 
 
 
 
 
 
 
gcc出错警告选项
-ansi
    强制gcc生成符合标准语法所要求的警告信息,但不能保证所用的错误都被找出
    gcc -ansi warning.c -o warning
-pedantic
   打印ANSI C标准列出的全部警告信息(同样不能保证所有的没有警告的程序都是符合标准的)
   gcc -pedantic warning -o warning
-Wall
  打印gcc能够提供的所有有用的警报信息
另外gcc能利用选项对单独常见错误分别指定警告


 
优化选项:
        通过编译选项“-On”控制优化代码的生成,n代表优化级数
       “-O” 主要进行线程跳转和延迟退栈,“-O2”“-O3”还进行一些额外优化工作
 
 
 
体系结构相关选项
 
 
 
 数据库
 
函数库:常用过公共函数编译并集成的二进制文件(ELF格式文件)
 
静态库:一系列目标文件(.o)的归档文件( libname.a ) 
             编译过程中被提取所需要的目标文件并复制到改程序的可执行二进制文件(ELF文件)
动态库:(libname.so),只在程序运行时才被载入,链接使用。
 
 
 
                材料 1.包含unsgn_pow,c函数的unsgn_pow.c文件
                        2.调用unsgn_pow()函数的pow_test.c
 
  静态库创建:    
                   (1)使用归档工具ar,将目标文件集成在一起
                    # gcc -c unusgn_pow.c
                    # ar rscv libpow.a unsgn_pow.o
                    a - unsgn_pow.o
 
                  (2) 编译主程序来观看一下结果
                   #  gcc -o pow_test pow_test.c -L. -lpow
                   #  ./pow_test 2 10
                   2.^10=1024
                   "-L dir" :在库文件的搜索路径中添加dir目录
                  "-lname" 选项指示编译时连接到库文件libname.a或libname.so
 
 
动态库创建:
            1. 使用gcc的-fPIC选项为动态库构造一个目标文件
                  # gcc -fPIC -Wall -c unsgn_pow.c
                2.使用-shared选项和已创建的位置无关目标代码,生成动态库libpow.so
                  # gcc -shared -o libpow.so unsgn.so
               3.编译程序(将链接到刚生成的动态库lipow.so)
                 # gcc -o pow_test pow_test.c -L. -lpow
      
          运行可执行程序前需要注册动态库的路径名,有几种方法,如下:
            1.修改 /etc/ld.so.conf文件
               2.修改 LD_LIBRARY_PATH环境变量
              3.将库文件直接复制到 /lib或者 /usr/lib  目录下(这两个都是系统默认的库路径名)
           结果:
              # cp libpow.so /lib
              # ./pow_test 2 10
              2 ^ 10 =1024
           
 
 
  **ar 
功能说明:建立或修改备存文件,或是从备存文件中抽取文件。

语  法:ar[-dmpqrtx][cfosSuvV][a<成员文件>][b<成员文件>][i<成员文件>][备存文件][成员文件]

补充说明:ar可让您集合许多文件,成为单一的备存文件。在备存文件中,所有成员文件皆保有原来的属性与权限。
linux 下ar 命令的详细解释
 
 
 
gdb
 
程序保存退出后用gcc进行编译,一定要记得加上选项“-g”这样编译出来的可执行代码才包含调试信息
# gcc -g test.c -o test
 
gdb调试的是可执行文件,而不是源代码
  • gdb programm(启动GDB)
  • b 设断点(要会设4种断点:行断点、函数断点、条件断点、临时断点)
  • run 开始运行程序
  • bt 打印函数调用堆栈
  • p 查看变量值
  • c 从当前断点继续运行到下一个断点
  • n 单步运行
  • s 单步运行
  • quit 退出GDB
(1)查看文件
键入“l(list)”查看文件
 
(2)设置断点
在“b(break)”后加入对应行号,如“b 6”,此时程序会在第六行之前停止,并不会运行到第六行。
 
(3)查看断点情况
         设置断点后,可以键入“info b”来查看断点情况,gdb中可以设置多个断点
         在断点输入“bt(backrace)”查看调用函数(堆栈)的情况,常用于排出错误或监视调用堆栈的情况
 
(4)运行代码
    gdb默认从首行开始运行代码,键入“r(run)”(从指定行开始运行代码,在r后加上行号)
 
(5)查看变量值
    程序停止运行后,查看断点相关处变量值 键入“p+变量值”
 
(6)单步运行
    可以使用“n(next)”和“s(step)”
    两者查别:s会进入函数,而n不会进入函数
 
(7)恢复程序运行
            使用命令“c(continue)”执行剩余命令,并显示剩余命令的执行结果,
            程序完成后退出,之后程序进入”停止状态“。
 
 
 gdb基本命令
 
    gdb的命令可以使用help查找(分为class,进一步查找相关命令helo class)
   已知命令 help [command]
   
 
 
 (1)工作环境相关命令
 
 
 
(2)设置断点与恢复相关命令
 
 
gdb中的断点设置方法。
gdb中多种断点设置方式:按行设置断点设置函数断点条件断点
 
(1)函数断点
格式:  b+函数名
此断点其实是在函数定义处
 
(2)条件断点
格式: b 行数 / 函数名  if 表达式 
例:b 8 if i==10
 
 
 
gdb源码查看相关命令
 
 
gdb查看相关运行数据相关命令
 
 
 
gdb中修改运行参数相关命令
    设置方法:“set 变量= 设定值”
 
    只有代码处于“运行”或“暂停”状态时才能查看变量值
 
 
 
 
 make工程管理器
 
 
 
一个makfile通常包含的内容
需要有make工具创建的目标体(target),通常指目标文件和可执行文件
需要创建的目标所以依赖的文件(dependency_file)
创建每个目标体所需要运行的命令(command)这一行必须由制表符Tab开头
格式:
        target:dependency_files
        commmand /*必须由制表符Tab开头*/
  例:这里有两个文件hello.c和hello.h  
        目标体:hello.c    
        执行命令:gcc -c hello.c
        对应makefile:hello.o:hello.c hello.h
                                gcc -c hello.c -o hello.o
 
make的 使用格式make target
 
make允许makefile中创建和使用变量(用来代替文本字符串,该字符串成为该变量的值)
make中定义变量方式:1.递归展开方式    
                                     2.简单方式 
 
 
1. 递归展开方式
                        这种方式定义的变量,在引用变量时进行替换,如果有内嵌变量,将会一次性全部展开
                         缺点:不在变量后追加内容(可能造成无限循环)
                        格式:VAR=var
2.简单方式
                        此方式在定义处展开,并只展开一次。不包含对其他变量的引用,从而消除变量套用
                        格式:VAR:=var
 make中的变量均使用格式:$(VAR)
 
*关于变量名:1.不包含“:”“#”“=”以及结尾空格的任何字符串
                       2.大小写敏感(推荐使用小写,大写留做控制隐含规则参数/用户重载命令选项参数的变量名)
 
 
make clean就会去执行rm -f *.o test这条命令,完成 clean 操作
 
 
变量分类用户自定义变量,预定义变量自动变量,环境变量
 
1.常见预定义变量
 
 
2.常见自动变量
 
 
 
 
make的规则:
 
1.隐藏规则:make会自动搜索隐式规则目录来确定如何生成目标文件(只能使用默认变量
  隐式规则指出所有“.o”文件都可以自动由”.c“文件使用:”$$(CC)$$(CPPFLAGS)$$(CFLAGS) -c file.c -o file.o“来生成
 
常见隐式规则目录
 
2.模式规则
   用来处理相同处理规则的多个文件,这里可以使用用户自定义变量,这个规则的相关文件必须使用”%“标明
 
 
 
make管理器的使用:
make +目标名
直接运行make,则建立makefile的第一个目标
 
make命令行选项
 
 
 
 
 
 
 问题解决:
1.先把材料看了一遍,果然还是不知道该如何动手,在教学视频中大概了解了操作的方法后,操作起来就熟悉很多。
2.在网上了解到ar命令的作用
linux 下ar 命令的详细解释
 
 
 
 
 
 此次学习到的命令操作真的非常的多,并不是短期可以快速掌握的,做好对常用命令分类梳理,以及灵活使用帮助工具非常重要。