当前位置: 首页 > 编程日记 > 正文

我的vim捣鼓之路


  • 2016-06-13 更新 绑定独立博客到域名rebootcat.com

  • 2016-06-12
    更新文中的几个链接错误,google search报错

前言

从大二的时候就开始接触Linux了,从而也接触了vi,对的,当时对这些还不太了解,不知道还有个vim,真的觉得入门不简单,网上关于vim对比其他Editor的学习曲线,看了令人生畏。那时候用的也不多,所以一直处于裸奔状态,只会基本的操作,这里推荐我比较喜欢的一个博客网站酷壳中的一篇博文简明vim练级攻略。这篇博文基本上把日常使用vim的90%的命令概括了,裸奔也就够了.

当然,这里推荐一个关于vim的游戏vim大冒险,同样来自酷壳.这个网站里很多博文我都觉得写的不错。写这篇博文的时候又看到上面一个比较有趣的命令。
在vim中试着输入 :h! 会发现什么? 输入 :h 42呢?是不是很有趣?

还有,这里多说一句,关于vim,Emacs等,两个阵营可以无休无止的争论下去谁更优秀。我作为一个vimer,我只引用一句话:

Emacs是神之编辑器,vim是编辑器之神。

闲言少叙,开始正文,这是我在从最初接触vim到现在快3年了,终于决定不裸奔了。

什么是插件

vim 是一个支持丰富的插件扩展的Editor,那么什么是插件?可以简单的理解,插件就是一个配置,只不过需要把插件放在相应的目录下,比如
~/.vim/plugin下,然后在~/.vimrc中做相应的配置即可。这点理解了,对于vim的配置就会相对明朗很多。所以,对于新增插件,就是不断把插件放在~/.vim/plugin目录下的过程。

当然,对于使用插件管理器的情况就有些不同。这里我自己使用的是Vundle.这样就不用自己管理插件了,删除,更新,安装插件将变得很简单,很容易。

插件管理器Vundle的安装

参照github上Vundle的教程安装好Vundle.然后你会发现~/.vim/目录有bundle目录,~/.vim/bundle/目录将是即将安装的插件的存放目录。即通过vundle安装的插件将都存在这个目录下。
先贴一张我自己的Vundle:

对应上图,我使用到的vim插件如下:

序号插件名功能
1delimitMate自动补全引号(单引号/双引号/反引号), 括号(()[]{})
2vim-surround方便的在字符两边插入各种符号 (我不用)
3indentLine代码缩进标识
4nerdtree文件目录树
5taglist代码结构概览
6syntastic语法检查
7YouCompleteMe终极神器,代码补全

目前暂时用到这些个插件,后续如果有新的实用的插件会更新。

delimitMate 安装

自动补全引号(单引号/双引号/反引号), 括号(()[]{})

只需要在.vimrc文件中增添一句:

Bundle 'Raimondi/delimitMate'

演示效果:

vim-surround 安装

方便的在字符两边插入各种符号

在.vimrc文件中增添一句:

Bundle "tpope/vim-surround"

演示效果:(借用了其他博主的图片,侵删)

indentLine 安装

代码缩进标识

在.vimrc文件中增添下面几句:

Bundle 'Yggdroot/indentLine' 
"indentLine 代码缩进线标志线
let g:indentLine_char = '¦' 
let g:indentLine_color_term = 239 
"映射到ctrl+i键 
map <C-i> :IndentLinesToggle<CR> 

演示效果:

nerdtree 安装

文件目录树

在.vimrc文件中增添:

Bundle 'scrooloose/nerdtree.git'
"NERD-tree  explore ,映射到ctrl+e 
map <C-e> :NERDTreeToggle<CR> 

演示效果:

taglist 安装

代码结构概览

在.vimrc文件中增添:

Bundle 'vim-scripts/taglist.vim.git' 
map <silent> <F1> :TlistToggle<CR> `

演示效果:

结合cscope将能实现linux下的代码浏览,虽然比不上windows平台的sourceinsight(个人觉得,也可能是自己还没有把快捷键用熟悉),后面将会专门写一篇博文关于cscope,此处留空

终极神器YouCompleteMe

为什么说终极神器呢?我是从windows转到linux的,大学里一直在用VS,那时候还是死死的编程,一个代码一个代码的敲,直到有一天我发现了visual assist x ,这个虚拟助手简直让我爽得不能自拔,它能自动补全。而且效率很高。当然如果你要开始鄙视我了,那没办法,我还不是大神,大神当然不用这些自动补全神器,降低身份。转到linux后,一直用裸奔的vim,所以也没有遇见YouCompleteMe这类的神器。直到有一天,终于忍无可忍,我以后还要接着用vim的,网上关于vim大神用vim收发邮件,听mp3,煮咖啡的传说一直让我怀疑,又让我跃跃欲试,况且vim没用过几个插件的人怎么好意思说自己vimer,甚至linuxer?终于开始捣鼓起自己的vim配置。

工作中最先开始用centos5的,无奈自带的gcc版本,vim版本,Python版本过低,一路折腾,自己编译了vim 7.4版本, gcc 4.8版本,Python3版本,在编译libclang(YouCompleteMe就是依赖clang进行补全和词法分析的)时还是不通过,折腾了快两周后,终于决定放弃centos5,转战centos7。这个过程很痛苦,说实在的,google了很多很多前人的解决办法,但是依旧没能成功编译YouCompleteMe,这个过程实在浪费时间,也学不到什么,所以建议如果可能的话,尽量采用较高本版的系统吧。这里虽然轻描淡写,但是浪费最多时间的地方也就是这一步。下面记录几个当时收藏用以解决这个问题的网址,当然只是作为记录,我用不到,不过依旧感谢这些博主。

Getting Started with the LLVM System : http://llvm.org/docs/GettingStarted.html

centos安装vim7.4: http://www.cnblogs.com/nhlinkin/p/3545509.html

CentOS 升级Python3.4.3版本: http://www.centoscn.com/image-text/config/2015/0320/4931.html

centos 6.5 x64编译有python的vim7.4 - yantze: http://www.tuicool.com/articles/rUNfMbJ

vim安装YouCompleteMe插件http://www.cnblogs.com/junnyfeng/p/3633697.html

[笔记]ubuntu 13.04 配置YouCompleteMe: http://blog.csdn.net/zhuliting/article/details/20055715

vim自动补全神器: http://blog.marchtea.com/archives/161

Ubuntu 15.04下为Vim安装YouCompleteMe插件: http://www.linuxidc.com/Linux/2015-07/120352.htm

linux下编译安装YouCompleteMe插件http://hahaya.github.io/build-YouCompleteMe/

Building LLVM with CMake: http://llvm.org/docs/CMake.html

centos下安装llvm+clang:

http://ilovers.sinaapp.com/article/centos%E4%B8%8B%E5%AE%89%E8%A3%85llvmclang

How To Install LLVM and Clang on CentOS 6:

https://www.vultr.com/docs/how-to-install-llvm-and-clang-on-centos-6

RPM resource libclang.so()(64bit):

http://rpmfind.net/linux/rpm2html/search.php?query=libclang.so%28%29%2864bit%29++centos&submit=Search+…&system=&arch=

Index of /gnu/gcc/ :http://mirrors.kernel.org/gnu/gcc/

http://howiefh.github.io/2015/05/22/vim-install-youcompleteme-plugin/

http://howiefh.github.io/2015/05/22/vim-install-youcompleteme-plugin/

好了,那么我把linux换成centos7了,然后参照YouCompleteMe上的教程,很轻松的就安装好了YouCompleteMe,不需要自己去编译clang,不需要很费心费力的google。

演示效果:

那么说说.vimrc的配置:

"YouCompleteMe 配置
let g:ycm_global_ycm_extra_conf = '/home/niki/.ycm_extra_conf.py'  
" let g:ycm_global_ycm_extra_conf = '/home/niki/.vim/bundle/YouCompleteMe/third_party/ycmd/cpp/ycm/.ycm_extra_conf.py'  
let g:ycm_seed_identifiers_with_syntax=1    " 语法关键字补全  
let g:ycm_confirm_extra_conf=0   " 打开vim时不再询问是否加载ycm_extra_conf.py配置  
"youcompleteme  默认tab  s-tab 和自动补全冲突
"let g:ycm_key_list_select_completion = ['<Down>']
"let g:ycm_key_list_previous_completion = ['<Up>']
"在注释输入中也能补全
let g:ycm_complete_in_comments = 1 
"在字符串输入中也能补全
let g:ycm_complete_in_strings = 1 
"注释和字符串中的文字也会被收入补全
let g:ycm_collect_identifiers_from_comments_and_strings = 0 
let g:ycm_error_symbol = '>>'
let g:ycm_warning_symbol = '>*'
"回车即选中当前项 
inoremap <expr> <CR>  pumvisible() ? "\<C-y>" : "\<CR>"  
set completeopt=longest,menu    "让Vim的补全菜单行为与一般IDE一致(参考VimTip1228) "上下左右键的行为 会显示其他信息
inoremap <expr> <Down>     pumvisible() ? '<C-n>' : '<Down>'
inoremap <expr> <Up>       pumvisible() ? '<C-p>' : '<Up>'
inoremap <expr> <PageDown> pumvisible() ? '<PageDown><C-p><C-n>' : '<PageDown>'
inoremap <expr> <PageUp>   pumvisible() ? '<PageUp><C-p><C-n>' : '<PageUp>
"Vim calls this "prefix" key the "leader". You can set your leader key to
"whatever you like.
let mapleader = ","
nnoremap <leader>gj :YcmCompleter GoToDeclaration<CR>
nnoremap <leader>gf :YcmCompleter GoToDefinition<CR>
nnoremap <leader>gg :YcmCompleter GoToDefinitionElseDeclaration<CR>
nmap <F4> :YcmDiags<CR>

上述配置信息,如果你对map或者nnoremap不懂,对leader不懂,推荐你看这篇Learn Vimscript the Hard Way.

syntastic 安装

据说YouCompleteMe集成了Syntastic,这一步或许不必须。我自己是安装上了。
这能很实时的检查你的代码的语法,词法,错误等。应该很有用。

在.vimrc中添加:

"syntastic  语法错误检查 
execute pathogen#infect()
set statusline+=%#warningmsg#
set statusline+=%{SyntasticStatuslineFlag()}
set statusline+=%*
"每次自动调用 :SyntasticSetLocList, 将错误覆盖 **quickfix**
let g:syntastic_always_populate_loc_list = 1
" 自动拉起/关闭错误窗口, 不需要手动调用 :Errors
let g:syntastic_auto_loc_list = 1
let g:syntastic_check_on_open = 1
let g:syntastic_check_on_wq = 1
map <F2> :SyntasticToggleMode<CR>

配置应该也比较简单,映射到F2键激活/关闭Syntastic的语法检查窗口。
演示效果:

Vundle安装,更新,卸载插件

利用插件管理器的好处就在于方便。
打开vim:

安装插件:

:BundleInstall

更新插件:

:BundleUpdate

卸载插件:(先在.vimrc文件中注释掉需要卸载的插件)

:BundleClean
演示效果:

涉及到每一个插件的使用,需要仔细研究配置文件每一行代码的作用,理解并熟悉快捷键的使用。如果不熟悉快捷键,效率将会慢得很多很多。

其他

到此为止,我目前所用到的插件基本就上面的几个,虽然也碰到了一些还不错的插件,但是对于我来说并不实用。我主要从事linux上的c/c++开发,暂时用到的这些能满足我的需求,如果以后还有更好玩的更实用的插件,我会接着更新。作为记录,也说不定能帮到其他人。

现在回头在写这篇博客的时候,大致浏览了下,又觉得好简单啊,当时怎么就觉得挺折腾呢?也许这就是成长的过程。回过头的时候总觉得当时怎么那么傻,当时应该还能做的更好点。。。

这严格来说算我的第一篇博文,自己搭建的基于github Pages的博客,暂时先用着github Pages,后续如果自己能坚持下来写博客,那么再考虑购买域名和服务器。

Related Posts

跟我一起学习VIM - The Life Changing Editor

我的vim配置及说明【k-vim】

超详细的vim+cscope 的使用规则 转载

The End

email:linuxcode2niki@gmail.com

Blog:

  • rebootcat.com (默认)

  • http://linxi4linux.github.io/(原地址,备用)

  • http://reboot_cat.coding.me/ (原地址,备用

2016-6-7 于杭州

相关文章:

代码写对了还挂了?程序媛小姐姐从 LRU Cache 带你看面试的本质

来源 | 码农田小齐责编 | Carol 前言在讲这道题之前&#xff0c;我想先聊聊「技术面试究竟是在考什么」这个问题。技术面试究竟在考什么在人人都知道刷题的今天&#xff0c;面试官也都知道大家会刷题准备面试&#xff0c;代码大家都会写&#xff0c;那面试为什么还在考这些题&…

广船国际股份有限公司OA项目

2003年的老案例&#xff1a; 背景 广船国际股份有限公司是由原中国船舶工业总公司属下国有企业广州造船厂在1993年改组、在上海和香港同期上市的股份有限公司&#xff0c;公司享有自营进出口权。 广船国际于2002年3月通过评标后选定采用iOffice.net信息管理平台作为信息化建设…

注册表----修改Win7登录界面

在进行操作前&#xff0c;需要准备好背景图片。对背景图片的要求有三点&#xff1a; &#xff08;1&#xff09;图片必须是JPG格式&#xff1b; &#xff08;2&#xff09;必须将图片命名为backgroundDefault; &#xff08;3&#xff09;图片的体积必须小于256KB。 按下【WinR】…

定义自己的rm command

rm 是一个很危险的命令&#xff0c;别人一直说&#xff0c;我并没有在意&#xff0c;直到有一天一个不小心&#xff0c;忘记当前目录的位置&#xff0c;手贱的使用了rm命令&#xff0c;结果花了半天也没有把那些重要资料给恢复过来。所以还是有必要给自己定义一个不那么危险的r…

出任 Twitter 独立董事,AI 女神李飞飞的传奇人生

作者 | 年素清责编 | 伍杏玲出品 | 程序人生&#xff08;ID&#xff1a;coder_life&#xff09; 近日&#xff0c;Twitter宣布任命斯坦福大学计算机科学教授、前谷歌副总裁李飞飞为董事会独立董事。李飞飞本人表示&#xff1a;“推特是科技连接世界的一个重要平台&#xff0c;…

apache ab压力测试

2019独角兽企业重金招聘Python工程师标准>>> ab的原理&#xff1a;ab命令会创建多个并发访问线程&#xff0c;模拟多个访问者同时对摸一个URL地址进行访问。它的测试目标是基于URL的&#xff0c;因此它既可以用来测试apache的负载压力&#xff0c;也可以测试nginx、…

我的个人博客搭建记录

6/13更新 绑定个人博客到域名 rebootcat.com 前言 本篇博客旨在备忘&#xff0c;并记录了自己折腾了3,4天后顺利搭建自己的个人博客过程中碰到的一部分问题。 搭建个人独立博客有很多种方法&#xff0c;我暂时采用的是基于github Pages的免费博客&#xff0c;博客框架采用he…

oracle中创建触发器

从csdn上面看到一个如何创建触发器的问题&#xff0c;感觉自己很有必要保存学习&#xff0c;特写下来&#xff1a;条件&#xff1a;现有A、B两张表A&#xff1a; 工号 姓名 密码 性别 年龄 。。。B&#xff1a; 工号 姓名 密码当对A表中的“密码”字段进行修改时,B表中的“密码…

量子计算与AI“双拳”出击,他们锁定38种潜在抗疫药物

作者 | Just出品 | AI科技大本营&#xff08;ID:rgznai100&#xff09;医药研发行业有一个“三个十”的说法&#xff0c;即一种药物的发现需要投入十年以上的时间&#xff0c;花费十多亿美元&#xff0c;最后获得10%的成功率。也就是说&#xff0c;医药研发需要花费很长时间&am…

Android官方开发文档Training系列课程中文版:OpenGL绘图之应用投影与相机视图

原文地址&#xff1a;http://android.xsoftlab.net/training/graphics/opengl/projection.html##transform 在OpenGL ES环境中&#xff0c;投影相机View可以将所绘制的图形模拟成现实中所看到的物理性状。这种物理模拟是通过改变对象的数字坐标实现的&#xff1a; 投影 - 这基于…

Python分析101位《创造营2020》小姐姐,谁才是你心中的颜值担当?

来源 | CDA 数据分析师责编 | Carol Show me data&#xff0c;用数据说话。今天我们聊一聊《创造营2020》各个小姐姐&#xff0c;点击下方视频&#xff0c;先睹为快&#xff1a; 最近可以追的综艺真是太多了&#xff0c;特别是女团选秀节目。之前我们刚聊过《青春有你2》&…

体验Remix——安卓电脑

第一次听说Android-X86 以前玩唱吧的时候接触过PC上的安卓模拟器&#xff0c;不过这个只是一个软件&#xff0c;效果毕竟不好&#xff0c;想要把电脑变成安卓手机&#xff0c;还差远了。 然后&#xff0c;前段时间一直纠结要不要换个手机&#xff0c;我现在的华为小6已经跟我…

重置 microsoft visual studio窗口

“工具”->“导入导出设置”—>“重置所有设置”&#xff0c;在这个向导中可以重置编译环境的&#xff01;转载于:https://www.cnblogs.com/qiantuwuliang/archive/2011/05/31/2064825.html

排序算法总结之堆排序

一&#xff0c;堆排序介绍 堆是一个优先级队列&#xff0c;对于大顶堆而言&#xff0c;堆顶元素的权值最大。将 待排序的数组 建堆&#xff0c;然后不断地删除堆顶元素&#xff0c;就实现了排序。关于堆&#xff0c;参考&#xff1a;数据结构--堆的实现之深入分析 下面的堆排序…

Hessian通信案例(java)

个人博客&#xff1a; 戳我,戳我 前言 由于工作的原因&#xff0c;接触到了hessain,项目需要做hessain和xml之间的报文转换。但是对于hessian是个什么东西一头雾水。于是接下来的时间了解了hessain协议的序列化规则以及hessian协议进行通信的方式。这篇文章是在完成了这个模块…

VDI序曲二十一 APP-V 4.6 SP1服务器端部署

APP-V是微软应用程序虚拟化除RemoteApp以外非常棒的另一种应用程序虚拟化&#xff0c;此应用程序虚拟化是把搭开应用程序消耗的资源放在前端&#xff0c;应用程序虚拟化主要解决的还是软件兼容性问题和保护软件资产问题&#xff0c;同时让用户无需安装就可以绿色使用的手段&…

绝悟之后再超神,腾讯30篇论文入选AI顶会ACL

作者 | 马超责编 | Carol出品| AI科技大本营&#xff08;ID&#xff1a;rgznai100&#xff09;封图 | CSDN 付费下载于东方 IC近日&#xff0c;国际计算语言学协会年会ACL在官网(https://www.aclweb.org)公布了2020年度的论文收录名单&#xff0c;其中腾讯共有30篇论文入选&…

mac中用命令行运行mysql

1&#xff0c;安装mysql 在mysql的官方网站下载 mysql 5.5.23 http://www.mysql.com/downloads/mysql/&#xff0c;根据我的机器的配置情况选择了64bit版本。 2&#xff0c;命令行中启动mysql 安装的位置在/usr/local/mysql 于是做了一个别名&#xff1a; $alias mysql/usr/loc…

Hessian源码分析(java)

个人博客&#xff1a; 戳我&#xff0c;戳我 先扯一扯 前一篇博文Hessian通信案例(java)简单实现了Java版的Hessian客户端和服务端的通信&#xff0c;总体看来&#xff0c;实现起来比较简单&#xff0c;整个基于Hessian的远程调用过程也显得很方便。但是知其然还要知其所以然&…

必读!53个Python经典面试题详解

作者 | Chris翻译 | 苏本如&#xff0c;编辑 | 夕颜题图 | 视觉中国出品 | AI科技大本营&#xff08;ID:rgznai100&#xff09;本文列出53个Python面试问题&#xff0c;并且提供了答案&#xff0c;供数科学家和软件工程师们参考。不久前&#xff0c;我作为“数据科学家”开始担…

Microsoft Web 平台安装程序 (Web PI) Microsoft Web Platform Installer

Microsoft Web 平台安装程序 3.0 (Web PI) 是一款免费的工具&#xff0c;使用它可以获得 Microsoft Web 平台的最新组件&#xff08;包括 Internet Information Services (IIS)、SQL Server Express、.NET Framework 和 Visual Web Developer&#xff09;。Web PI 的内置Window…

Linux Shell 脚本限制ssh最大用户登录数

原创作品&#xff0c;允许转载&#xff0c;转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://dgd2010.blog.51cto.com/1539422/1670233 我撰写本文原来的意图是想把“复制SSH渠道”和"copy SSH Session"这样的功能从远程s…

hessiancpp编译和使用(C++版)

个人博客&#xff1a;戳我&#xff0c;戳我 许下的承诺 前两篇博客Hessian通信案例(java)和Hessian源码分析(java)介绍了Java版的hessian的使用以及源码分析。当时也说过打算写一下C版的hessian的使用和源码分析&#xff0c;现在就是兑现承诺的时候了。其实我项目中实际用到的…

美国AI博士一针见血:Python这样学最容易成为高手!

我见过市面上很多的 Python 讲解教程和书籍&#xff0c;他们大都这样讲 Python 的&#xff1a;先从 Python 的发展历史开始&#xff0c;介绍 Python 的基本语法规则&#xff0c;Python 的 list, dict, tuple 等数据结构&#xff0c;然后再介绍字符串处理和正则表达式&#xff0…

win7操作系统在哪显示隐藏文件夹

win7操作系统在哪显示隐藏文件夹 打开计算机--组织--文件夹和搜索选项--查看--把 “隐藏受保护的操作系统文件”前面的钩去掉&#xff0c;选中“显示隐藏的文件、文件夹和驱动器”--确定

ASP.NET MVC4中调用WEB API的四个方法

当今的软件开发中&#xff0c;设计软件的服务并将其通过网络对外发布&#xff0c;让各种客户端去使用服务已经是十分普遍的做法。就.NET而言&#xff0c;目前提供了Remoting,WebService和WCF服务&#xff0c;这都能开发出功能十分强大的服务。然而&#xff0c;越来越多的互联网…

使用docker制作hexo镜像

个人博客&#xff1a;戳我&#xff0c;戳我 背景 这段时间一直在折腾我的博客&#xff0c;由于之前出现过一次电脑硬盘完全挂掉的情况&#xff0c;为了避免重新搭建博客系统&#xff0c;一直打算搞一个方便点的环境&#xff0c;能进行多机迁移之类的。正好&#xff0c;Docker完…

3D目标检测深度学习方法数据预处理综述

作者 | 蒋天元来源 | 3D视觉工坊&#xff08;ID: QYong_2014&#xff09;这一篇的内容主要要讲一点在深度学习的3D目标检测网络中&#xff0c;我们都采用了哪些数据预处理的方法&#xff0c;主要讲两个方面的知识&#xff0c;第一个是representation&#xff0c;第二个数据预处…

NTLM协议认证

第一篇blog&#xff0c;发现这是个记录学习过程的好地方。从基础的开始吧。 NTLM&#xff1a; 基本知识telnet的一种验证身份方式&#xff0c;即Windows NT LAN Manager (NTLM)&#xff1b; NTLM 是为没有加入到域中的计算机&#xff08;如独立服务器和工作组&#xff09;提供的…

新盒模型移动端的排版

这里采用的是新盒模型来进行排版&#xff1a; <div class"mytest">   <header></header>   <section></section>   <footer></footer> </div> 在CSS样式里添加如下样式 html,body{ height: 100%; } .mytest{ …