这是My vimrc

我发现在终端中加载.vimrc会花费很长时间:

$ vim --startuptime myvimrctime
$ cat myvimrctime
....
152.762  147.219  054.849: sourcing $HOME/.vimrc
....

我已经对viminfo做了一些优化:
  set viminfo=%,<800,'10,/50,:100,h,f0,n~/.vim/cache/.viminfo

但是仍然需要太多时间。

这是time vim:
[marslo@MarsloJiao ~]
$ time vim
real    0m1.877s
user    0m0.204s
sys         0m0.028s

如何减少Vim的启动时间?谢谢。

顺便说一句,这三个项目也花费了很多时间,如下所示,在vim启动之后,有什么方法可以启动这些文件吗?
050.213  043.340  043.340: sourcing /home/marslo/.vim/tools/vim74/share/vim/vim74/filetype.vim
050.334  044.509  000.409: sourcing /home/marslo/.vim/tools/vim74/share/vim/vim74/syntax/syntax.vim
143.985  040.931  037.467: sourcing /home/marslo/.vim/tools/vim74/share/vim/vim74/filetype.vim

奇怪的是, 054.490 的时钟无缘无故跳到 141.158 (vundle配置仅占用000.184):
054.490  000.184  000.184: sourcing /home/marslo/.vim/bundle/vundle/autoload/vundle/config.vim
141.158  002.377  002.377: sourcing /home/marslo/.vim/bundle/vim-ruby/ftdetect/ruby.vim

我再次创建了新的--startuptime文件。以下是完整的日志:
times in msec
 clock   self+sourced   self:  sourced script
 clock   elapsed:              other lines

000.013  000.013: --- VIM STARTING ---
050.538  050.525: Allocated generic buffers
110.662  060.124: locale set
124.156  013.494: GUI prepared
222.567  098.411: clipboard setup
222.610  000.043: window checked
465.327  242.717: inits 1
465.344  000.017: parsing arguments
465.348  000.004: expanding arguments
465.383  000.035: shell init
465.846  000.463: Termcap init
465.912  000.066: inits 2
466.107  000.195: init highlight
682.019  000.574  000.574: sourcing /home/marslo/.vim/tools/vim74/share/vim/vim74/syntax/syncolor.vim
682.360  001.624  001.050: sourcing /home/marslo/.vim/tools/vim74/share/vim/vim74/syntax/synload.vim
740.232  031.815  031.815: sourcing /home/marslo/.vim/tools/vim74/share/vim/vim74/filetype.vim
740.351  073.003  039.564: sourcing /home/marslo/.vim/tools/vim74/share/vim/vim74/syntax/syntax.vim
740.490  000.023  000.023: sourcing /home/marslo/.vim/tools/vim74/share/vim/vim74/filetype.vim
784.275  000.101  000.101: sourcing /home/marslo/.vim/tools/vim74/share/vim/vim74/ftplugin.vim
863.519  056.517  056.517: sourcing /home/marslo/.vim/tools/vim74/share/vim/vim74/macros/matchit.vim
865.282  001.188  001.188: sourcing /home/marslo/.vim/tools/vim74/share/vim/vim74/ftoff.vim
1000.218  000.258  000.258: sourcing /home/marslo/.vim/bundle/vundle/autoload/vundle.vim
1054.471  000.234  000.234: sourcing /home/marslo/.vim/bundle/vundle/autoload/vundle/config.vim
1585.009  002.401  002.401: sourcing /home/marslo/.vim/bundle/vim-ruby/ftdetect/ruby.vim
1589.847  000.516  000.516: sourcing /home/marslo/.vim/bundle/vim-javascript/ftdetect/javascript.vim
1600.298  000.232  000.232: sourcing /home/marslo/.vim/bundle/vim-javascript-syntax/ftdetect/javascript.vim
1609.818  000.376  000.376: sourcing /home/marslo/.vim/bundle/vim-markdown/ftdetect/mkd.vim
1638.215  124.558  121.033: sourcing /home/marslo/.vim/tools/vim74/share/vim/vim74/filetype.vim
1640.109  000.055  000.055: sourcing /home/marslo/.vim/tools/vim74/share/vim/vim74/ftplugin.vim
1651.369  000.189  000.189: sourcing /home/marslo/.vim/tools/vim74/share/vim/vim74/indent.vim
1681.203  000.767  000.767: sourcing /home/marslo/.vim/tools/vim74/share/vim/vim74/syntax/syncolor.vim
1686.380  000.729  000.729: sourcing /home/marslo/.vim/tools/vim74/share/vim/vim74/syntax/syncolor.vim
1689.126  000.719  000.719: sourcing /home/marslo/.vim/tools/vim74/share/vim/vim74/syntax/syncolor.vim
1691.276  027.443  025.228: sourcing /home/marslo/.vim/bundle/marslo.vim/colors/marslo256.vim
1692.803  1160.345  877.776: sourcing $HOME/.vimrc
1692.839  066.387: sourcing vimrc file(s)
1720.420  000.418  000.418: sourcing /home/marslo/.vim/bundle/ctrlp.vim/autoload/ctrlp/mrufiles.vim
1720.883  009.810  009.392: sourcing /home/marslo/.vim/bundle/ctrlp.vim/plugin/ctrlp.vim
1742.318  001.396  001.396: sourcing /home/marslo/.vim/bundle/tagbar/plugin/tagbar.vim
1747.987  000.292  000.292: sourcing /home/marslo/.vim/bundle/authorinfo/plugin/authorinfo.vim
1758.222  003.409  003.409: sourcing /home/marslo/.vim/bundle/EnhCommentify.vim/plugin/EnhancedCommentify.vim
1779.670  002.103  002.103: sourcing /home/marslo/.vim/bundle/supertab/plugin/supertab.vim
1788.557  001.838  001.838: sourcing /home/marslo/.vim/bundle/auto-pairs/plugin/auto-pairs.vim
1809.937  001.491  001.491: sourcing /home/marslo/.vim/bundle/snipmate.vim/plugin/snipMate.vim
1813.891  000.471  000.471: sourcing /home/marslo/.vim/bundle/Conque-Shell/plugin/conque_term.vim
1854.376  019.755  019.755: sourcing /home/marslo/.vim/bundle/mru.vim/plugin/mru.vim
1856.948  001.377  001.377: sourcing /home/marslo/.vim/bundle/taglist.vim/plugin/taglist.vim
1877.552  003.597  003.597: sourcing /home/marslo/.vim/bundle/winmanager/plugin/winfileexplorer.vim
1882.273  004.192  004.192: sourcing /home/marslo/.vim/bundle/winmanager/plugin/winmanager.vim
1894.960  001.489  001.489: sourcing /home/marslo/.vim/bundle/winmanager/plugin/wintagexplorer.vim
1918.938  000.482  000.482: sourcing /home/marslo/.vim/bundle/python_fold/plugin/python_fold.vim
1944.447  001.214  001.214: sourcing /home/marslo/.vim/bundle/vim-rails/plugin/rails.vim
1998.414  002.073  002.073: sourcing /home/marslo/.vim/bundle/vim-textobj-user/autoload/textobj/user.vim
2015.845  048.452  046.379: sourcing /home/marslo/.vim/bundle/vim-textobj-rubyblock/plugin/textobj/rubyblock.vim
2034.279  000.329  000.329: sourcing /home/marslo/.vim/bundle/ruby-matchit/plugin/ruby-matchit.vim
2063.907  001.131  001.131: sourcing /home/marslo/.vim/bundle/vim-surround/plugin/surround.vim
2105.056  018.511  018.511: sourcing /home/marslo/.vim/bundle/rainbow/plugin/rainbow.vim
2130.447  000.401  000.401: sourcing /home/marslo/.vim/tools/vim74/share/vim/vim74/plugin/getscriptPlugin.vim
2131.959  000.904  000.904: sourcing /home/marslo/.vim/tools/vim74/share/vim/vim74/plugin/gzip.vim
2132.955  000.557  000.557: sourcing /home/marslo/.vim/tools/vim74/share/vim/vim74/plugin/matchparen.vim
2134.955  001.501  001.501: sourcing /home/marslo/.vim/tools/vim74/share/vim/vim74/plugin/netrwPlugin.vim
2135.455  000.100  000.100: sourcing /home/marslo/.vim/tools/vim74/share/vim/vim74/plugin/rrhelper.vim
2135.852  000.084  000.084: sourcing /home/marslo/.vim/tools/vim74/share/vim/vim74/plugin/spellfile.vim
2136.666  000.501  000.501: sourcing /home/marslo/.vim/tools/vim74/share/vim/vim74/plugin/tarPlugin.vim
2137.312  000.215  000.215: sourcing /home/marslo/.vim/tools/vim74/share/vim/vim74/plugin/tohtml.vim
2137.972  000.335  000.335: sourcing /home/marslo/.vim/tools/vim74/share/vim/vim74/plugin/vimballPlugin.vim
2138.870  000.540  000.540: sourcing /home/marslo/.vim/tools/vim74/share/vim/vim74/plugin/zipPlugin.vim
2157.065  000.696  000.696: sourcing /home/marslo/.vim/bundle/indentLine/after/plugin/indentLine.vim
2184.847  006.999  006.999: sourcing /home/marslo/.vim/bundle/snipmate.vim/after/plugin/snipMate.vim
2185.397  359.386: loading plugins
2187.454  002.057: inits 3
2195.983  008.529: reading viminfo
2242.679  046.696: setup clipboard
2242.716  000.037: setting raw mode
2242.760  000.044: start termcap
2242.859  000.099: clearing screen
2247.092  004.233: opening buffers
2248.580  001.488: BufEnter autocommands
2248.593  000.013: editing files in windows
2249.224  000.631: VimEnter autocommands
2249.231  000.007: before starting main loop
2251.990  002.759: first screen update
2251.999  000.009: --- VIM STARTED ---

最佳答案

您的~/.vimrc是源代码,这意味着Vim会在初始化时对每一行进行评估,包括您的所有函数。您应该将所有功能移至autoload目录。有关详细信息,请参见:help autoload,但这是一个简化的示例。

如果您的~/.vimrc中有此代码:

function! MyFunc()
    " code
endfunction

autocmd BufWinEnter * call MyFunc()

您可以创建~/.vim/autoload/functions.vim并将函数移到其中:
function functions#MyFunc()
    " code
endfunction

并将其保留在您的~/.vimrc中:
autocmd BufWinEnter * call functions#MyFunc()

在这种形式下,Vim不需要解析函数,直到实际调用它为止。

另一个优化可能是将所有autocmd FileType移至正确的ftplugins。

现在,在您的~/.vimrc中:
autocmd FileType ruby setlocal something

之后,在~/.vim/after/ftplugin/ruby.vim中:
setlocal something

关于vim - 如何减少vim的启动时间?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/21194354/

10-12 20:57