V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
skywind3000
V2EX  ›  Vim

Vim/Emacs 深度比较

  skywind3000 · 2017-01-06 04:12:17 +08:00 · 14748 次点击
这是一个创建于 2860 天前的主题,其中的信息可能已经有所发展或是发生改变。

生命在于折腾,折腾完了 Atom Editor ,开始跟着陈斌大婶和 purcell 的配置折腾 Emacs ,比较下。很多人都在比较键位,比较插件,这是十分肤浅的,我们比较点深入的东西:

代码结构

Emacs 源代码: eLisp 79%, C 21% 

Vim 源代码: C 52%, VimScript 48%

从代码结构上来讲, Emacs 的代码最多的是 elisp , C 代码只是一个微内核, Vim 里 C 代码还是大头。当然不排除 24.X, 25.X 以后 Emacs 源代码里带了好几个重量级的包,而 Vim 向来比较精简一些,官方没带啥大点的插件有关。去除自带插件后, Emacs 的 elisp 代码比例应该会下降很多,不过总体来说, Emacs 有更多组件使用 elisp 开发而成,也就是说可以被用户修改或者替换的地方比 Vim 要多,当然速度也会相应慢一点(比如 Emacs 新打开上万行的文件连续按住 PageDown 时 cpu 100%占满),不过比较大 JB , Atom Editor 来说,还是快不少。

系统接口

大框架基本类似:

Vim 可以操作: buffer, window, tabpage, 光标, marker, region 跳转表等等。 Emacs 可以操作: buffer, window, frame, 光标, marker , region 异步进程 等等。

Vim 有 local , Emacs 有 mode , Vim 有事件触发, Emacs 有各种钩子,基本大框架类似的。

键位设置也都很灵活,会配置的话,可以把 Emacs 键位全部弄成 Vim 的,比如 Evil ,或者 Vim 里面也可以配制成进去就自动进入插入模式,全部用 Emacs 键位。

具体到比如 buffer 或者窗口里面, Emacs 的窗口或者 buffer /window 属性更多一些, Vim 也有一些 Emacs 没有的基础设施,比如 jumplist, quickfix 之类的,不过 Emacs 也可以用插件实现,实现 jumplist 没问题,比较独立,但每个插件实现一个类似的 quickfix 的东西,实在是比较蛋疼。

脚本语言

VimScript 类似 Lua ,但更啰嗦些,没啥好说的,要上手可能就是 2-3 天的样子,主要是实际编写中熟悉各种 Vim 内部结构体系,以及 api 。

EmacsLisp 类似 clisp ,稍微有些区别而已。 clisp 中的向量: (vector 1 2 3 4) 在 elisp 中可以用中括号来表示:[1 2 3 4] 这样对减少小括号数量有一些帮助,代码读起来没那么拗口,可惜实际写 elisp 的过程中,向量用的并不多,各种插件用的最多的还是 list , alist , plist 几种容器,小括号还是满天飞,如果不借助编辑器的匹配,缩进,还有彩虹括号(不同层次的括号用不同颜色的小插件)代码很难阅读,自己写好写点,看别人代码要对括号对半天(特别是他们把很多写一行的话)。

Lisp 变量可视范围比较好用,局部变量可以 “遮盖住” 全局变量,比如你在 VimScript 里面要临时跳转到一个新目录需要这么写:

let cd = haslocaldir()? "cd" : "lcd"
let saved = getcwd()
silent! exec cd "my new directory"
......
silent! exec cd saved

而 elisp 里面,利用局部变量遮盖特性,简单的:

(let ((default-directory "my new directory"))
  .....
  )

在这个 let 的作用范围内, buffer 的全局变量 default-directory 被新定义的同名局部变量给遮盖住了,里面的代码(包括调用外面定义的函数)取这个名字的变量,都会取到你新定义的变量,作用范围结束就恢复了,这样比 vimscript 方便不少,类似的用法还有 (with-selected-window new-window...) 把当前窗口设置成 new-window 并做一些事情,当离开代码作用域以后,自动恢复成先前的窗口,如果 VimScript 来做这事情,又需要保存前窗口,然后跳转,最后又恢复。

VimScript 在 vim6.0 及以前的时代里比 EmacsLisp 弱很多,连个 List , HashTable 之类的容器都没有,怎么写复杂的程序嘛, Vim7.0 以后补充了字典和列表还有三元式,简单面向对象等,终于可以写点复杂的东西了,而 Vim 下很多传奇性的插件,其实也正是 7.0 以后才出现的。 Vim8.0 以后又进一步补充了匿名函数和 partial function (类似简陋版的 curry 函数)等等特性,除了啰嗦外,写点复杂东西问题不大,比如前久有人用 VimScript 写了一个 C 编译器,可以在 Vim 里跑 C 脚本。

Lisp 里面的宏类似 C++模版加强版, C++模版只有一层,定义好模版,然后生成代码。 Lisp 的宏可以先用程序生成模版,再由模版生成代码,类似模版的模版。不过实际使用中,为了不让自己的代码飞的太远,难以维护,大部分插件开发者在 elisp 里面最多就是 require 一下 common lisp 的兼容包,用一些 common lisp 里面诸如 loop, for, incf, case 之类的通用宏,自己定义也限于定义一些小工具,没有人丧心病狂的搞一些影响程序结构的东西,定义成另外一门语言。

大部分插件开发者实际上还是把它当作充满括号的 lua 来用,除去一些便利性外,麻烦也还是挺多的。

异步进程

早期的 Vim 没有异步进程操作,导致很多插件没有 Emacs 那么顺畅,比如生成 tag 或者编译, Vim 只有傻等着, Emacs 可以同时做其他事情, Vim8.0 以后异步接口和后台时钟等也比较完善了,假以时日各大常见插件能逐步发挥 8.0 特性的时候,相信也能带来一致的体验,包括纯 vimscript 实现的 shell ,以及 gdb 集成,发邮件等,问题不大。

实际使用中最紧缺的异步任务,虽然系统都支持,但是显然就插件来讲, Vim 的插件跟进的速度还有待提高,毕竟本身已经晚出了那么多年了。不过好在自己可以撸,熟悉 VimScript 的话,可以把最紧缺的 tag 生成,编译, grep 等几项日常使用频率最高的工作自己写插件异步化了,比如我自己撸的: skywind3000/asyncrun.vim

Vim 里面的 CtrlP (模糊文件查找),还有 tagbar (文件符号列表),先前用起来就是一个字 “卡”,经常卡住做不了别的事情。同比之下, Emacs 的 Helm 系列全家桶做文件模糊查找就顺畅的多。同样的 python 实时补全插件 jedi ,在 Vim 下会卡, Emacs 下很流畅也是这个原因。好在最新版的 CtrlP 已经增加了异步任务支持,可以后台检索文件,是没卡界面了,但是确实还需要时间进一步完善改 bug 。

Emacs 的 flycheck 被人津津乐道,方便的后台异步检查当前编辑文件的语法,并且标注出错的地方。 Vim 的同类产品 syntastic 以往会把界面卡住,你需要停下编辑,等着跑 lint 跑完了以后它才给你标注出来。所以很多人比较了 flycheck 以后,觉得 flycheck 很爽,一边写着,前面出错的地方就会被自动标注,根本不用停下来,于是坚定不移的转战了 Emacs 了。当然, Vim8.0 以后也出现了自己的异步检查插件:w0rp/ale

总体来说,目前异步进程两大编辑器支持都差不多了,但原有非异步的 Vim 的各大著名插件,还需要进一步跟进完善,才能提供更好的体验。

界面分离

Emacs 和 Vim 都支持 client/server 模式,但是不是一回事情, Vim 的 client/server 就是简单的给做服务的 Vim 实例发一些消息,执行一些代码, client 控制 server 打开一些文件而已。

Emacs 的 client/server 是真的 client/server ,界面和内在逻辑相分离,你可以在 GUI 的 Emacs 里面打开一堆文件,并在命令行版本的 Emacs 里面链接到 server 里面来共享多个 buffer 和状态,同时编辑,还可以在 Emacs 上面套一个壳,遵守一致通信协议下,完全用 Electron 来写个现代界面。

NeoVim 里面提供了类似的支持,界面逻辑相分离,而且比 Emacs 更进一步做了一个更漂亮一点的界面系统,比如有人用 Electron 给 NeoVim 做了一套 GUI ,前台是 javascript 做的界面,后台是 NeoVim 跑的逻辑: extr0py/oni

这个做的十分漂亮只能希望 Vim 早点支持,把 NeoVim 那部分界面 patch 给收录了。

org-mode

org-mode 适合用来安排 GTD ,写文档,整理思路之类的, Vim 下面确实没有可以代替的插件,有个 vim-org-mode ,实现的不伦不类的(vimoutliner/vimoutliner 比 vim-org-mode 更好一些)。

不过说道很多人对 org 模式赞不绝口的 GTD ,我多两句嘴,但凡用过现代 GTD 软件的,基本不会去用 org-mode 的 gtd ,现在 GTD 管理基本都在手机上做了,同时支持多端同步,手机采集素材和临时想法(包括不限于文字,照片,录音), PC 上用 PC 版或者 Web 版整理编辑日程,日常在手机上随时同步查看 next action ,这才是 GTD 的正确用法,我不知道各位 org 深度用户抱着 org 的 gtd 不放干嘛?是有一些同步 org 日程的方法,但都较为山寨又缺乏统一体验。

GTD 和各种 知识 /碎片收集整理的方法,我们还是使用各种多端同步的现代化解决方案吧。

其他优势

Emacs GUI 版本可以显示图形, Vim 这个就没法了。 Emacs Lisp 新版本支持多线程和 FFI ,可以调用外部动态库。 VimScript 没有这个能力,需要借助 Python 来做类似的事情。

最终比较

喜欢一个编辑器和喜欢一个人差不多,有的女的喜欢上一个男的,可能因为他的手长的比较好看,或者那天下午阳光明媚,他穿了一件白衬衫。

我不喜欢 Emacs 的地方,是窗口 /Frame 管理,十分猥琐:

  1. Emacs 的 Frame 比 Vim 的 TabPage 功能类似,但是 Emacs 的 Frame 确实比 Vim 的 TabPage 麻烦很多,比如 GUI 下面每个 Emacs 的 Frame 就是一个新窗口,而每个 GVim 的 tabpage 是一个 GUI 上的 TAB 。 Emacs 的这个设置相当恶心, Vim 下我可以设置 ALT_1234 来快速切换各个 tabpage ,而 Emacs 如果这么做, GUI 下面窗口用热键跳来跳去,你就会觉得相当怪异。直到现在 Emacs 的 Frame 用的人也不多,而 Vim 的 TabPage 确实十分顺手,这点不是插件可以解决的。

  2. Buffer 切换, Emacs 下面更多是模糊查找切换 buffer ,原始或者 helm 增强过的 c-x b ,快捷键绑定的上一个 buffer 或者下一个 buffer 。而 Vim 中,我可以用 ALT+数字来直接切 tabpage , ALT+SHIFT+数字来直接快速切换 buffer , emacs 下有类似插件,但往往用 emacs 的时候各种 buffer 开的太多,切换起来真心累。

  3. 我不喜欢正在编辑的文档或当前正在引用对照的文档被 emacs 的某些插件随时切换走,经常打开个 grep 或者编译什么的,还在看得一个文档就没了。不用提醒我有独占窗口, Emacs 的 reference 我基本都快速过过一遍了,我当然知道 (display-buffer ... ) 的时候有很多策略,窗口也可以设置成 dedicated window 。我告诉你们问题在哪里,如果你不想文件被切走,你就只能把很多窗口设置成 dedicated window ,而某插件想要显示自己时,粗暴的默认参数调用一下 (display-buffer .. ) 或者 (display-reuse-window ... ) 时,找不到可以显示自己的空间, Emacs 就会默认帮他打开一个新的 frame ,在 GUI 下面一个 frame 是一个新的 Emacs 窗口。所以你会觉得很诡异,用着用着,弹出一个新的 Emacs 窗口来,真他妈的操蛋。这不是你的错,是 Frame 机制和这些插件的问题。

  4. 过分依赖 ALT 键,导致终端下支持不太好,我好几个 ALT 键还想留给终端软件自己用呢,你全把我占完了,我不一次性把所有 ALT 隐射给你你还不能正常工作。 Vim 里面 ALT 键很和谐,终端软件用一部分 ALT 键快速操作跳转 ssh 窗口, Vim 自己用另外大部分补充 CTRL 的不足,十分宽松舒适。

  5. 缺乏统一标准,比如 Location list ,对就是 Vim 里面的 Quickfix 和 llist 之类的东西,就是我们普遍运行编译, grep ,生成查找 tag , lint 的时候会出现很多文件和行号, Quickfix 用来显示这些结果,选中一个就会跳转过去,这么一个东西。用 Emacs 当然可以用插件实现一个,小 case ,但是问题是:没有统一标准。各个插件都自己实现了一套,你编译时 emacs 弹出一个窗口或者占用一个你的老窗口显示编译结果,你查找 grep 的时候,又弄出一个新窗口来显示结果,你查找 tags 的时候,还会再弄一个新窗口出来,所以 Emacs 下面界面缺乏统一逻辑,有的插件新开窗口,有的插件替换窗口,窗口 buffer 满天飞。不停的开窗口,关窗口,切 buffer 。但 Vim 下面有标准的 Quickfix ,这些事情统统显示在下方 Quickfix Window 中,标准统一,还有系统级别的 api 来提供统一接口,还有相关配套插件来根据 quickfix 内容在源代码上以高亮标志出来,十分整洁, Vim 里插件们是互相协作的。这不是 Emacs 没有能力这么做,而是 Emacs 没有统一标准,导致碎片化严重,成天开关各种窗口,经常切换 buffer ,是 Emacs 里面的一项日常的日常, Vim 里面你从来不会觉得这些事情是一个负担。类似缺乏标准的还有各种 jumplist, 界面规范等。所以 emacs 里面经常你一套我一套,不得不靠一些 helm, company 等全家桶来提供统一的体验,然而治标不治本。

  6. Vim 的 buffer list 和预览窗口更好用一些,比如 vim buffer list 里面可以标注一个 buflisted 的属性,我在浏览 tags 时,很多时候都是在 preview window 里面预览一下,预览窗口里的文件默认是 buflisted=0 的,不会污染我的 buffer list , emacs 下面预览文件一多, buffer list 就乱了,你打开几个文件,还得一个个去 kill 去,准确的说 emacs 也可以用脚本实现一模一样的 bufferlist 和 preview window (当然 Vim 也可以脚本另实现一套 buflist+预览,还有上面的 quickfix 只是没人这么做),但还是上面那句话,没有标准,你自己实现了,也没有任何插件支持,你也不可能把所有插件全改一遍,来统一他们的界面逻辑,总之就是界面逻辑难统一,工作流混乱。

不同的地方很多,这里也总结不完,但是大体就是这些,非要让用一句话形容 Emacs 的话,那就是用 Emacs 就像 SM ,有的地方很爽,有的地方很疼。

嗯,折腾和试用结束,不是不强大,是不搭。

http://www.skywind.me/blog/archives/1951

...

40 条回复    2017-01-07 10:37:27 +08:00
lsmgeb89
    1
lsmgeb89  
   2017-01-06 04:21:54 +08:00 via Android
唉,没心思折腾编辑器,主要是记不住
xcv58
    2
xcv58  
   2017-01-06 04:27:05 +08:00 via iPhone
还是用面向二十一世纪的 Atom 吧
Miy4mori
    3
Miy4mori  
   2017-01-06 04:40:57 +08:00 via Android
还是用开箱即用的 JB 吧
zeal7s
    4
zeal7s  
   2017-01-06 04:46:35 +08:00
还是用高颜值的 vscode 吧
zeal7s
    5
zeal7s  
   2017-01-06 04:49:01 +08:00
@lsmgeb89 同感!编辑器用的熟练跟代码写得又快又好并没有直接关系。尝试学习 vim 和 emacs ,但是还是觉得鼠标更符合直觉,用得飞起
smilingsun
    6
smilingsun  
   2017-01-06 04:59:29 +08:00 via Android
楼主好强!
Tiande
    7
Tiande  
   2017-01-06 05:38:11 +08:00
选哪个都能用到死,一般码农可能 20% 的功能也用不到。
不想自己写插件的话,没必要折腾,选择别人打包好的上手用就行了。
congeec
    8
congeec  
   2017-01-06 06:34:27 +08:00
@zeal7s 用触摸板也很爽
gfexfizv
    9
gfexfizv  
   2017-01-06 06:36:59 +08:00 via iPhone
ctrlp+ctrlp-py-matcher 就不会卡了(文件特别多的目录)

neomake 也可以异步检查语法。
j5shi
    10
j5shi  
   2017-01-06 07:42:21 +08:00 via iPhone
用过 eclipse, vs2012, SI, vscode, ST2, Atom, Vim, emacs, 和一些专门的 IDE, 最终还是选择了 Vim ,因为它免费,据我所知很多文本编辑器还是要钱的,用盗版是很可耻的一件事情。并且它不像某些 IDE 那么庞大笨重,动辄几十个 G 的,而且又比那些花哨的编辑器效率高,打开两三个 G 的文本轻松加愉快,几百万行代码的工程进行文本搜索在速度上甩 vscode 几条街,而且它有众多插件的支持,很多编辑器上的功能都是模仿 vim 插件的,比如说 ctrlp ,几乎成了现代编辑器的标配了。而且在 Linux 上几乎都有 Vim ,甚至连嵌入式设备上都有…更重要的是它能给你带来装逼的愉悦…
firebroo
    11
firebroo  
   2017-01-06 08:23:27 +08:00 via Android
有的女的喜欢上一个男的。
cool4zbl
    12
cool4zbl  
   2017-01-06 08:27:06 +08:00 via iPhone
很棒!从各个方面进行了比较,对 vim 有了新理解。话说关注楼主博客很久了 ...
cool4zbl
    13
cool4zbl  
   2017-01-06 08:31:56 +08:00 via iPhone
想请教下, 除了有界面逻辑分离外, Neovim 与 Vim 差别大吗?使用 Vim 很久了,一直没体验过 Neovim 。如果只是为了一些新特性,从 Vim 迁移到 Neovim 成本高吗?以及有没有这个必要....
scarlex
    14
scarlex  
   2017-01-06 08:48:55 +08:00
写得太好啦,先撸为敬!
hzgmaxwell
    15
hzgmaxwell  
   2017-01-06 09:12:20 +08:00 via Android
harry890829
    16
harry890829  
   2017-01-06 09:31:49 +08:00
本来以为是引战贴,结果是科普贴……
itisthecon
    17
itisthecon  
   2017-01-06 10:02:38 +08:00 via Android
写的很好,学习了!
ijse
    18
ijse  
   2017-01-06 11:19:15 +08:00
很赞!

每隔一段时间就会花时间来整理优化编辑器配置,更新插件什么的。作为生产力工具需要不断地调校,不仅仅是为了提高工作效率,也是改善心情。
going2think
    19
going2think  
   2017-01-06 11:49:44 +08:00 via Android
开眼界了…
nG29DOMuRYTWfcSr
    20
nG29DOMuRYTWfcSr  
   2017-01-06 12:01:23 +08:00
写的很好,收藏,这是我收藏的第一个主题。
66beta
    21
66beta  
   2017-01-06 12:04:14 +08:00
atom 和 vsc 都敢来围观, sublime 笑而不语
arakashic
    22
arakashic  
   2017-01-06 12:42:52 +08:00
@cool4zbl 日常使用的差别微乎其微, neovim 是会 follow 上游的 vim 代码的(当然有的 patch 会被忽略,比如 vim8 的异步)。我从 vim 迁移到 neovim 的时候只有一个插件不兼容( color_coded ),所以迁移本身的成本很小(除非你已经在用 vim8 ,而且有不少异步插件)。不过我只是把开发用的机器迁移到 neovim 了,服务器还是用 vim ,都换成 nvim 太麻烦。
exoticknight
    23
exoticknight  
   2017-01-06 12:47:39 +08:00
盗版可耻然而软件要钱——那你就给钱买啊= =b
k9982874
    24
k9982874  
   2017-01-06 12:51:33 +08:00
把编辑器折腾成 IDE 本来就是邪道
zhuangzhuang1988
    25
zhuangzhuang1988  
   2017-01-06 12:57:43 +08:00
知乎的这个回答也不错 https://www.zhihu.com/question/21393299/answer/137479868
各位看下..
zhuangzhuang1988
    26
zhuangzhuang1988  
   2017-01-06 12:58:38 +08:00
@zhuangzhuang1988 擦, 我错了, 因为是盗版的, 楼主就是本人..
tedzhou1221
    27
tedzhou1221  
   2017-01-06 12:59:13 +08:00
MacOS 平台下,用 JB+VIM ,因为 MacOS 上快捷键非常类似 Emac ,所以这样我就用了 Emacs 和 VIM 的键位和用 JB 。

工具就是这样用,在不同的环境中使用更合适的工具!
yuuko
    28
yuuko  
   2017-01-06 13:37:13 +08:00 via Android
个人觉得, vim 是不可能收录 neovim 的特性的,除非 vim 自己实现,参考 vim 的异步特性,所以转向了 neovim
leitwolf
    29
leitwolf  
   2017-01-06 13:38:27 +08:00
@j5shi 两三个 G 的文件。。。
很好奇是啥文件。
spongebobsun
    30
spongebobsun  
   2017-01-06 13:42:25 +08:00
卧槽正好命中了我这最近折腾下来的痛点。最开始觉得 vim 用的越久就爱之深恨之切,尤其是 lint 卡住的时候真是不要不要的。然后前几天入坑 spacemacs ,用下来真是觉得窗口管理简直难用爆了。。。尤其是我喜欢打开多个文件的,来回切换不要太酸爽。

话说才发现韦老师也在 V 站~
rupert
    31
rupert  
   2017-01-06 14:54:31 +08:00   ❤️ 3
被称作“编辑器之神”和“神之编译器”的 Vim 和 Emacs 长期以来硝烟不断,而 IEEE CS 的一项最新研究则显示男性程序员选择使用 Vim 或者 Emacs 或许是和他们阴茎长度有关。

来自 MIT 理学院( School of Science)的费克博士和他的助手在同校的工程学院( School of engineering)的学生中分别随机抽取了一百名使用 Vim 和一百名使用 Emacs 的男性志愿者。并利用数位生物学( digital biology )技术对他们的生理指征进行了全面而细致的建模。他们花了三个月时间对这些数据进行了分析,并向 IEEE CS 社区提交了一份研究报告。这份报告认为程序员最终选择 VIM 还是 Emacs 或许是跟人类的某些生理指征有关,比如说阴茎的长度。


“我们采集的数据非常庞大,从血细胞密度到指关节密度都有细致收集,当然还有男性志愿者们的阴茎长度——我们认为它是必不可少的。”费克博士在接受 http://IEEE.tv 采访时如是说道。

尽管所采集的数据并未完全排除其他可能性的干扰,如教育和开发环境等。费克博士等人还是成功的将 Vim/Emacs 编辑器的选择同所采集的数据联系了起来。研究表示,在声明为 Vim 用户的一百名志愿者中,大多数人手指比较短小灵活;而声明为 Emacs 用户的一百名志愿者则有着手指较长,跨度较大的特点。除此之外,他们还观察到了另外一组有趣的数据:选择使用 Vim 的志愿者通常阴茎要比选择使用 Emacs 为主要编辑器的志愿者短小。

他们在这份长达 73 页的报告中分析称这可能是因为 Vim 编辑器键距相对较短,更适合手指短小灵巧的人;而 Emacs 需要用到大量的辅助键,更适合手指跨度较大的人。而手指的长度或跨度又恰好与男性生殖器官的长度呈现某种比例关系。

对于使用 ST VSC ATOM 等编辑器的人因为手指得不到高强度训练,而长期不能勃起
20015jjw
    32
20015jjw  
   2017-01-06 15:39:29 +08:00
我读到说
vim 其实好在设计理念
所有移动 /操作都可以组合 不像 emacs 要 hardcode
Technetiumer
    33
Technetiumer  
   2017-01-06 15:49:11 +08:00
Vim 是 Unix 思想
Emacs 是 All-in-One 思想

Vim 似乎是最牛逼的编辑器
Emacs 是自带编辑器的操作系统
odirus
    34
odirus  
   2017-01-06 16:06:13 +08:00
学习阶段、刚开始工作的时候都是用的 emacs ,现在使用的频率很少了,不过 emacs 的快捷键影响我太深了, IDE 里面我都是用的 emacs key binding ,否则太不习惯了。
webjin1
    35
webjin1  
   2017-01-06 16:33:50 +08:00
各有千秋吧.
j5shi
    36
j5shi  
   2017-01-06 17:16:56 +08:00 via iPhone
@leitwolf 基站的 log
j5shi
    37
j5shi  
   2017-01-06 17:31:56 +08:00 via iPhone
@exoticknight 你也可以选择不用
jyf
    38
jyf  
   2017-01-06 23:16:42 +08:00
@leitwolf 日志文件?
cool4zbl
    39
cool4zbl  
   2017-01-07 09:31:02 +08:00 via iPhone
@arakashic 感谢,现在基本是 Vim 8 ,但是异步插件用得挺少,就是觉得终端 Vim + Tmux 操作比起 IDE 或者 App 编辑器稍微有些延迟...
Xrong
    40
Xrong  
   2017-01-07 10:37:27 +08:00
大神啊
关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3350 人在线   最高记录 6679   ·     Select Language
创意工作者们的社区
World is powered by solitude
VERSION: 3.9.8.5 · 26ms · UTC 10:58 · PVG 18:58 · LAX 02:58 · JFK 05:58
Developed with CodeLauncher
♥ Do have faith in what you're doing.