进行有效编辑的七种习惯

7 篇文章 0 订阅
 Bram Moolenaar 

如果你的很多时间是用来敲纯文本,写程序或HTML,那么有效地使用一个好的编 
辑器能节省你不少时间。这篇文章里的指导和提示将有助于你更快工作,更少犯 
错误。 

文中采用开源文本编辑器Vim(Vi IMproved)说明有效编辑的思想,但这些思想也 
适用于其他编辑器。择合适的编辑器只是有效编辑的第一步,对于哪个编辑器更 
好的讨论将占很大地方,这里就不提了。如果你不知道该用哪个编辑器,或者对 
现在所使用的不太满意,不妨试试Vim;你是不会失望的。 

第一部分:编辑一个文件 

快速定位 

编辑中大部分时间是花费在阅读、查错和寻找应该进行编辑的地方上,而不是插 
入新文字或进行修改。在文件中不断定位(navigate)是经常要做的,所以最好学 
会如何快速地进行。 

你常会搜寻文档中的一些文字。或者找出包含特定词或词组的行。你当然可以使 
用搜寻命令 /pattern,不过还有更聪明的方法: 

* 如果你看到一个特定词,想看看其他地方是不是出现过同样的词,可以使用 
* 命令。它将对光标所指的词进行搜寻。 
* 如果设置了 ' incsearch' 选项,Vim将在你正在输入搜寻模式的时候就 
显示搜寻的结果(而不是等到你敲了回车之后)。这能够使你更快地找出拼写 
错误。 
* 如果设置了 ' hlsearch' 选项,Vim将使用黄色背景对搜寻结果进行高亮 
显示。你可以对搜寻的结果一目了然。应用在程序代码中可以显示变量的所有 
引用。你甚至不需要移动鼠标就能看到所有的搜寻结果。 



对于结构化的文档,快速定位的办法就更多了。Vim提供专门针对C程序(以及 
C++、Java等等)的特殊命令: 


* 使用 %可以从开始括号跳到对应的关闭括号。或者从 ``#if'' 跳到对 
应的 ``#endif''。事实上, % 可以完成许多对应项之间的跳转。可 
以用来检查if()和{}结构是否平衡。 
* 使用 [{可以在代码段(block)中跳回到段起始的 ``{``。 
* 使用 gb 可以从引用某个变量的地方跳转到它的局部声明。 



定位的方法当然不止这些。关键是你需要知道有这些命令。你也许会说不可能学 
会所有命令 — Vim里有成百个定位命令,有的很简单,有的很聪明 — 这需要 
几星期的学习。不过,你不必如此;你只需要了解自己的编辑特点,然后掌握相 
关的定位命令就可以了。 

可以采取三个基本步骤: 


1. 在你进行编辑的时候,注意那些重复进行的操作。 
2. 找出能快速进行这些操作的编辑命令。阅读文档,问问朋友,或者看看其他 
人是如何做的。 
3. 进行练习,知道熟练为止。 



让我们通过以下这个例子说明一下: 


1. 你发现在写C程序时,经常要查找函数定义。你目前使用 * 命令对函 
数名进行搜寻,但得到的往往是函数的引用而不是函数定义。你觉得一定会 
有更好的办法。 
2. 读过一篇快速参考以后,你发现关于定位标记的说明,里面说明了如何定位 
函数定义,这正是你要找的! 
3. 你试着生成了一个标记文件,使用Vim自带的ctags程序。你学会了使用 
CTRL-] 命令,发现这省了不少事。为了更方便,你在 Makefile 里加 
入了几行以自动生成标记文件。 



当你使用以上三个步骤时,有几点需要注意的地方: 


* ``我只想完成任务,不想去读那些文档来找新的命令。''。如果你真的是这 
么想的,那么你将永远停留在计算的石器时代。有些人编写什么都用 
Notepad,却总不明白为什么其他人总能用他一半的时间成任务。 
* 不要过分。如果你总为一点小事也要去找完美的命令,你就没法集中精力到 
你本要完成的任务上了。只要找出那些耗费过多时间的操作,然后使用相关 
的命令直到熟练就可以了。这以后你就能集中精力到自己的文档上了。 



下面这些章节给出了大多数人遇到的操作。你仿照它们在实际工作中使用 
三个基本步骤。 

不要敲两次 

我们所使用的字词集合是有限的。既使是词组和句子也不过是有限的几个。对于 
程序来说更是如此。很明显,你不想把同样的东西敲上两遍。 

你经常会想把一个词替换成另一个。如果是全文件替换,你可以使用 
:s (substitute)命令。如果只是几个位置需要被替换,一个快速办法是使 
用 * 命令找出下一个词,使用 cw 来进行替换。然后敲 
n 找到下个词,再用 . 重复 cw 命令。 

. 命令重复上一个改变。这里的改变是插入、删除或替换操作。能够重复 
进行操作是个极为强大的机制。如果好好使用它,那么你大部分的编辑工作可能 
只不过是敲几下 . 的事。小心不要在两次重复之间做其他修改,因为这 
将改变你要重复的操作。如果确实需要如此,可以使用 m 命令记住要修 
改的位置,等重复操作进行完毕之后再回过头来修改它。 

有些函数名和变量名可能很难敲。你能准确无误地输入 
``XpmCreatePixmapFromData''么?Vim的自动补齐机制能给你省不少事。它查看 
你正在编辑的文件以及#include文件,你可以只敲入``XpmCr'',然后使用 
CTRL-N 命令让Vim把它补齐为``XpmCreatePixmapFromData''。这不但节省 
了输入时间,而且减少了输入的错误。 

如果你有同样的词组或句子需要输入多次,还有个更简单的办法。Vim可以进行 
录制宏。使用 qa 命令开始在'a'寄存器里录制宏。然后正常地输入编 
辑命令,最后用 q 退出录制状态。如果你想重复所录制的命令,只需 
执行 @a 命令。Vim总共提供26个这样的宏寄存器。 

使用宏录制功能可以记录各种操作,不只限于插入操作。如果你想重复一些东西, 
不妨一试。 

需要注意的是记录的命令会被原封不动地重复执行。在进行定位时简单的重复宏 
操作可能不是你想要的结果。比如对于一个词这里可能需要左移4个字符,在下 
个地方可能就要左移5个字符。所以必须定位到合适的位置再重复进行宏操作。 

如果你要重复的命令很复杂,把它们一次敲进去会很困难。这时你可以写一个脚 
本或宏。这常被用于建立代码模板;比如,一个函数头。你想做得多聪明就可以 
做得多聪明。 

知错就改 

编辑时经常会出错。无人能免。关键是快速发现并进行改正。编辑器应该提供这 
方面的支持,不过你必须告诉它什么是对什么是错。 

你可能常常会重复同样的错误,你的手指所做的并非是你要它做的。可以使用缩 
写(abbreviation)进行修正。下面是一些例子: 


* :abbr Lunix Linux 
* :abbr accross across 
* :abbr hte the 


这些词会在编辑时被自动改正。 

同样的机制也可以用于对很长的词语进行缩写。特别适用于输入那些你觉得很难 
敲的词,它可以避免出错。比如: 


* :abbr pn pinguin 
* :abbr MS Mandrake Software 


但有时候你想要的正是那些缩写,比如想插入``MS''。所以缩写中最好使用那些 
不会出现在文中的词。 

Vim提供了一个很聪明的高亮机制,一般用于程序的语法高亮,不过也可以用来 
查错。 

语法高亮会使用颜色显示注释。这听上去不是什么特别重要的功能,不过一旦用 
起来就会发现这其实很有用。你能够快速地发现那些没有高亮却本应作为注释的 
文字(可能是因为忘了敲注释符)。也可以发现一些被错误当成注释的代码(可 
能是因为忘了敲``*/'')。这些错误在黑白方式下是很难被发现的,浪费了不少 
调试时间。 

语法高亮也可以用来查找不匹配的括号。一个未被匹配的``)''会被亮红色背景 
加以标识。你可以使用 % 命令他们是被如何匹配的,然后把``(''或 
``)''插入到合适的位置。 

另一类常犯的错误也很容易发现,比如把 ``#include <stdio.h>''敲成了 
``#included <stdio.h>''。在黑白方式下这是很难发现的,但在语法高亮下 
则能很快发现``include''能被高亮而``included''没有。 

再看一个更复杂的例子:对于英文文本你可以定义一个所要使用的词的长列表。 
所有未在表中出现的词都可能是错误,并进行高亮显示。可以定义几个用于编辑 
词表的宏。这正是字处理器的拼写检查功能。Vim中是靠一些脚本来实现的,你 
也可以对它进行定制:比如,只对注释中的文字进行拼写检查。 

第二部分:编辑多个文件 

文件总是成帮结伙 

人们很少只编辑一个文件。一般需要顺序或同时编辑一些相关的文件。你应该利 
用编辑器使多文件编辑工作更为高效地。 

上面提到的标识(tag)机制也支持跨文件搜寻。一般做法是为项目的所有文件生 
成标识文件,然后在项目的所有文件中搜寻函数、结构、类型(typedef)等的定 
义。这比手工搜寻要快捷的多;我浏览一个程序要做的第一件事便是建立标识文 
件。 

另一个强大的功能是使用 :grep 命令对一组文件进行模式搜寻。Vim把 
搜寻结果做成一个列表,然后跳到第一个结果。使用 :cn 命令跳到下 
一个结果。如果你想改变一个函数调用的、参数个数,那么这个功能会很有用。 

头文件里有很多有用的信息。然而要知道一个声明出现在哪个头文件中却需要花 
不少时间。Vim能够理解头文件,能够从中找到你需要的东西。把光标移动到函 
数名下,然后敲 [I:Vim就会显示出一个头文件中该函数名的所有匹配。 
如果你想得到更详细的结果,可以直接跳到声明中。一个类似的命令可以用于检 
查你所使用的头文件是否正确。 

你可以把Vim的编辑区域进行分隔,用来编辑不同的文件。你可以对两个或多个 
文件进行比较,或者进行拷贝/粘贴。有许多命令用于打开关闭窗口,文件间跳 
转,暂时隐藏文件等等。可以再使用上面提到的三个基本步骤选择合适的命令进 
行学习。 

多窗口还有更多的用法。预览标识(preview-tag)就是个很好的例子。它打开一 
个特殊的预览窗口,光标还保留在你正在编辑的文件中。预览窗口中可以是光标 
所指函数的声明。如果你移动光标到另一个名字下,停留一两秒,预览窗口中就 
会显示那个名字的定义。名字还可以是头文件中声明的结构或函数。 

让我们一起来工作 

编辑器可以编辑文件。e-mail程序可以收发消息。操作系统可以运行程序。每个 
程序都有它自己的任务,而且应该做好。如果能让程序一同工作,那么就会实现 
很强大的功能。 

举个简单的例子:选择一个列表中的结构化的文字,并对它进行排序: 
!sort。这将使用外部命令``sort''来过滤文件。容易吧?排序功能是可以 
添加到编译器中的。不过看一下``man sort''就知道它有很多选项。它可能用了 
一个极为精巧的排序算法。你还打算把它加到编辑器中么?更何况还有其他不少 
过滤程序。编辑器可能会变得很大。 

Unix精神的一个体现就是提供独立的程序,各自做好自己的任务,然后组合起来 
完成更大的任务。不幸的是,许多编辑器不能很好地和其他程序一起工作,比如, 
你不能包Netscape的邮件编辑器换成其他编辑器。这样你只能使用那个不顺手的 
程序。另一个趋势是在编辑器里提供所有的功能,Emacs就是个代表(有人说 
Emacs其实是个操作系统,只是可以用来编辑文件)。 

Vim尽力和其他程序集成,但这需要经过斗争。目前Vim已经可以作为 
MS-Developer Studio和Sniff的编辑器。一些e-mail程序(比如Mutt)也支持外 
部编辑器。和Sun Workshop的集成工作正在进行中。总的来说这个领域还有待提 
高。将来我们会有一个大于其各部分总和的系统。 

文本结构化 

你可能经常会遇到有一些结构的文本,这些结构可能同于那些现有命令所支持的 
结构。这样你不得不利用那些底层的``砖头''创建你自己的宏和脚本。这里说明 
的就是这类更复杂的东西。 

有个简单的办法可以加速编辑-编译-修改这个循环。Vim提供 :make 命 
令,用于进行编译,并且获取错误输出,把你带到发生错误的地方进行修正。如 
果你使用了另一个编译器,那么错误就无法被Vim获得。如果不想自己动手,可 
以修改' errorformat'选项。告诉Vim错误是什么样子,以及如何从中获 
得文件名和行号。它支持复杂的gcc错误信息,所以应该也能支持其他编译器。 

有时处理一个新的文件类型只需要设置几个选项或写一些宏。比如,为了在man 
手册中进行跳转,你可以写一个宏获取光标下的词,清除缓冲区,然后读入新的 
man手册。这是简单而高效的参照(cross-reference)方法。 

使用三个基本步骤,你可以更有效地处理各种结构化文件。只需要想想你想对文 
件采取的操作,然后找到相应的命令去用就是了。就这么简单,你只要去做就成 
了。 

第三部分:磨刀 

养成习惯 

要学会开车必须下功夫。这是不是你只骑自行车的原因么?当然不是,你会发现 
你必须花时间来获得所需的技术。文本编辑也不例外。你需要学习新的命令,并 
使用它直至成为习惯。 

另一方面,你不应该试图学习编辑器提供的每个命令。这是彻底的浪费时间。大 
多数人只需要学习10%到20%的命令就足够工作了。但是每个人所需要的命令都 
各不相同。你需要不断学习,找出那些可以自动完成的重复操作。如果你只做一 
次操作,而且以后也不会再去做,那么就不需要进行优化。是如果你发现你在过 
去的一小时中重复了好几遍同样的操作,那么就有必要查看一下手册,看看能否 
更快速地完成。或者写一个宏来做。如果是是个不小的任务,比如对一类文本进 
行对齐,你需要阅读一下新闻组或看看Internet上是不是有人已经解决了同样的 
问题。 

最根本的步骤是最后的那一个。你可能能够找到一个重复性的任务,找到一个不 
错的作法,可过了一个周末就彻底忘了自己是怎么做的了。这不成。你必须重复 
你的作法直到烂熟于胸。只有这时你才真正获得了你需要的高效。一次不要学得 
太多。一次只试一些工作得很好的方法。对于那些不常用的技巧,你可能只需要 
把它记下来,留待以后查阅。总之,如果抱着这样的目标,你的编辑技能就会更 
加有效。 

最后需要指出的是,如果人们忽略了以上几点会发生什么:我仍然可以看到有人 
盯着屏幕看上半天,用两个指头敲几下,然后继续抬头看着屏幕,还抱怨自己太 
累.. 把十个指头都用上!这不光更快,还不累。每天抽出一个小时练习一下指 
法,只要几星期就足够了。 

后记 

书名得益于Stephen R. Covey所著的那本畅销书《高效人的七种习惯》(``The 7 
habits of highly effective people'')。 

关于作者 

Bram Moolenaar是Vim的主要作者。他编写了Vim核心功能,并采纳了许多开发者 
提供的代码。他的e-mail地址是:Bram@Moolenaar.net
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值