zoukankan      html  css  js  c++  java
  • 一年成为Emacs高手(像神一样使用编辑器)

    一年成为Emacs高手(像神一样使用编辑器)

    作者:陈斌(redguardtoo)

    版本:20140722

    更新时间: 2014-07-22 Tue

    原创时间: 2012-01-31 Tue

    版权:本文採用下面协议进行授权,自由转载 - 非商用 - 非衍生 - 保持署名 | Creative Commons BY-NC-ND 3.0,转载请注明作者及出处.

    1 简单介绍

    成为 Emacs 高手非常easy.一年前我还在 Vi 阵营,偶尔用 Emacs 还忘记"退出"的快捷键,但一年后我跨入高手行列.

    非常多文章都是强调 Emacs 有多牛,以激发你的兴趣.最有名的大概是王垠Emacs 是一种信仰!世界最强编辑器介绍.

    这些好文章让你激动,你因此定下一个伟大目标 (掌握神一样的编辑器 Emacs),接下来就是运行了 (怎样高效地学习 Emacs).

    网上关于"怎样做"的文章不多,那些涉及到 "怎样做" 的文章,涉及细节多而谈方法论少,所以本文的重点就是谈谈一般方法.

    全文结构大致例如以下:

    • 首先会介绍为什么Emacs值得学习,假设你对开源文化相当熟悉认同可跳过这一章,否则至少应读一下态度一节.
    • 然后就是本文最核心的观点,尽快掌握Emacs的关键步骤.
    • 后面几章是进一步提高技巧的方法提示(社区,阅读,知识管理)
    • 当你提高到一定阶段,你应该能跳出详细Emacs技巧,赞赏Emacs的品味和其使用者的气质
    • 最后是答疑和小结

    2 为什么要用Emacs(可选)

    简单谈谈,由于我本文的重点是"怎么做",而不是"为什么".

    2.1 Emacs 的特点决定了其社区的平均技术水准都不低

    Emacs 用 Lisp 开发,Lisp 的不同平常的语法决定了其开发人员都是资深开发人员,掌握了多门语言.

    Emacs 本身并不能给你带来不论什么优点,这就决定了其社区成员都是纯粹的技术人员,投机取巧的功利主义者对其是没有兴趣.

    2.2 和单纯的 IDE 比較,Emacs 能够做的很多其它更快

    这里的很多其它并非和 IDE 比支持某编程语言的特性很多其它,而是指 Emacs 内可完毕的通用任务比較多更快捷.

    比如,我做开发时碰到难题,须要实时上 IRC 请教国外高手 (工作流包含粘贴我的代码到 pastebin 或者 gist,在 irc 内提问,看网页,将解决方式粘贴回来),emacs 集成了 IRC 工具和浏览器 (w3m),操作就非常方便.

    我使用 Visual Studio 多年了,Firefox 使用我也是高手,相信我,大多数情况下还是 Emacs 更快.

    当然口说无凭,请看下面两段高手操作的 youtube 视频:

    2.3 Emacs 是自由软件基金会开发的招牌开源软件

    个人会丧失开发软件的兴趣,公司会倒闭而停止维护软件.可是自由软件基金会会一直存在下去.Emacs 作为其招牌软件也会一直维护下去,我在其上投资永远不会贬值.

    2.4 使用 Emacs 能够立马開始工作.

    软件是开源的,配置是纯文本,并且软件的资源消耗较小,安装包非常小 (命令行版本号的安装包 30M 左右),所以在不论什么环境下我都能够用 Emacs 開始工作,overhead 非常小.

    这在大项目中特别明显,比如,某项目我须要同一时候编辑 perl、java、C、bash、SQL,须要远程编辑在美国server上的代码,网速也不是非常快.Emacs 的优势就体现出来了.

    2.5 一年指的是充分利用空暇时间,一年后自然水到渠成

    我没说一年内必须什么事也不干专门学 Emacs,悬梁刺股没有短期利益回报的学习方法是我最反对的.

    我赞成的方法是,開始阶段花极少的时间得到巨大的回报 (例如以下文谈到的 Org-mode),以兴趣做导向.

    每天花多少时间取决于个人须要和怎样管理,以我为例,每天八小时上班时间中有非常多零碎时间能够利用,上下班通勤时间有一个小时能够利用.

    2.6 态度决定一切

    长期来说你能取得的成就是由态度决定的.

    优秀人士的特点:

    1. 勇于接受新事物
    2. 追求更强的过程本身就是目的
    3. 举一反三

    比如,尽管 Emacs 默认的快捷键已非常高效,可是我更新了我的快捷键操作.保存文件时我原来要按按 "Ctrl+X Ctrl+S",如今按 ",ww".少按了一个键,同一时候手指避免了额外移动一寸去按 Ctrl 键.

    这似乎是个微小的修改,由于保存文件并非一个非常频繁的动作.并且放弃熟悉的快捷键操作,使用一个陌生的快捷键開始也有点不习惯 (后文我提到,我也是一个熟练的 Vim 用户,可是 Vim 的保存快捷键默认是 ":w",并非如今的键位).

    可是这仅仅是我改进效率的一个开端,我花了几个月时间把全部的操作都以类似的方法优化了一边. 然后我又想到了进一步的优化应该有可靠的统计数据为基础,所以我安装了名为 keyfreq 的 Emacs 插件,对于我使用最频繁的操作又一次分配了最方便的快捷键.

    如果我一開始由于已习惯了 Vim 或者 Emacs 默认的快捷键,或由于改进保存文件动作的效率提升太小,所以拒绝改变,那么就不会有后来的大规模优化键位的project.

    或者有人说输入代码效率仅仅是软件开发流程中非常小一部分,重要的是 "XXXX(编程思想,架构,框架…)".此所谓顾左右而言它.假设你能举一反三,自然能够猜到相同的方法和原则也适用于软件开发的不论什么一部分," 可是…" 仅仅是不做的借口罢了.

    3 详细步骤

    Emacs本质上是给geek(热爱技术,追求高效的人)使用的软件.所以使用它须要一点点Linux的基本知识.假设你没有这方面的经验,那么下一节"无Linux经验新手高速指南"就是为你准备的.否则可跳过.

    步骤的要点在于起点要高,照抄高手的配置,尽量理解高手的配置,不要改动,除非你要给高手报bug.

    熟悉配置后应增加社区,使用高手开发的插件,培养品味.到达一定的程度后要回报社区,多做測试,多报bug.

    3.1 无Linux/Unix经验新手的高速指南(可选)

    下面是我的建议:

    • 安装Emacs 24
    • 不要安装不论什么第三方插件
    • 掌握基本知识,什么是环境变量(比方PATH, HOME之类的变量),什么是stdin, stdout, pipe.
    • 读官方教程,学会主要的文本操作(大概十几个快捷键)
    • 使用Emacs 24自带的org-mode作为你的个人时间管理软件.
    • org-mode关键是用起来,仅仅要记住按TAB键是展开内容就能够了,其它都不用学.

    实际上我在后文已经把这个怎样入手的问题说得非常清楚了.

    比方我后文谈到,我就是从org-mode入手的,又谈到你应跟着高手学习而不要自己瞎摸索.假设能举一反三,你应想到假设你不确定从何处着手,那么跟着我做(用org-mode)应该是不会错的.

    3.2 读官方教程

    打开 Emacs 后,同一时候按下 Alt 和 X 健,输入 help-with-tutorial(后文中,类似快捷键以简写 `M-x help-with-tutorial` 取代),回车.

    仅需半小时.关于 Emacs 的多难学的谬论能够休矣,由于半小时的代价微不足道.想想你去年有多少小时白白虚度了吧.

    这步是必须的,不要跳过!

    比如,非常多人的问题是不知道怎样查看变量函数的文档,这在官方教程中都有说明.

    3.3 以兴趣和急需解决的问题作为切入点

    由于假设微小的努力能得到巨大的回报,你就会越学越有乐趣,进入一个感情上的正反馈.

    长期来说,在不论什么领域要成为高手,兴趣是最重要的.

    以我为例,我急需 GTD 的工具,而 Emacs 的 org-mode 是世界上最好的 GTD 工具 (没有之中的一个). 用 org-mode 大大节省了时间后,我对于 Emacs 爱屋及乌,兴趣高涨了 100 倍.

    让我再举个反面的样例说明,Emacs的email软件Gnus尽管某些特定功能强大(比方高速插入邮件附件,生成HTML表格),可是因为非常长时间没有更新,其UI已相当落后于时代,对于一般用户来说其UI及其费解.

    我知道有资深的10年经验的Emacs用户也认为Gnus太难用.

    即使你终于学会了Gnus,能做的事也和Gmail的Web版本号有差距(比方搜索邮件,附件预览),并且Linux下也有很多同类软件.这就是典型的投资极大,回报非常小.

    所以对新手来说,从Gnus入手Emacs是非常成问题的.

    3.4 站在巨人的肩膀上

    这方面我是个负面模范.一開始我还是抱着玩的心态,喜欢到处找有趣的配置粘贴到我的 .emacs 中去.

    这是浪费时间!

    我应该一開始就照抄 世界级大师 Steve Purcellemacs 配置.

    警告,Purcell 总爱试用最新的 Web 开发的新技术,对他而言稳定性不是第一位的,假设你有足够的热情和能力,愿意和他一起折腾,那么你的 Emacs 水平会提高得非常快

    这个假设是非常重要的前提,当我上了 Purcell 的贼船时,我已有 10 年开发经验,精通多种开发语言.

    假设你不愿意过于折腾,那么你至少不要反复我的错误,你不要质疑,你不要创新,你要跟着高手做.比方 Eric Schulte 的 Emacs-starter-kit 非常适合刚開始学习的人.Bozhidar Batsov 的配置 也不错 (不一定适合刚開始学习的人).也能够用 我的配置.

    直说了把,你是刚開始学习的人,開始阶段应以学习模仿为主.这点怎么强调也只是分!

    为了加深印象,让我再举一个样例.一些读者向我反映,Emacs 快捷键太多,背起来压力非常大.实际上这是刚開始学习的人先入为主的偏见.对高手来说,有了恰当的工具后,快捷键非常多情况下并不须要.盲目地去背快捷键仅仅会延迟你成为高手那一刻的到来.假设你仅仅是复制了高手的配置開始使用而不是纠结于完毕背快捷键这个无聊的任务,你会发觉高手已安装了名为 smex 的插件,使得你直接输入命令比用快捷键还快.所以背快捷键也不须要了.

    这是本文最核心的观点, 假设你还没有信服的话,请再考虑一下我的理由:

    • 我文章的标题是 一年成为高手,不是一年入门.
    • 高手是世界级别的高手,不是关起门来一个特定小圈子内的高手
    • 我就是这么做的,你能够看看一年内我给他报了多少 bug.
    • 说究竟是态度问题,假设你真正下定决心了,考虑到Purcell的天赋和勤奋,追赶他的最好办法显然仅仅有增加他.
    • 要超越世界级高手就必须了解高手的标杆在哪里,你须要一年的时间去模仿去学习.
    • 你基于Purcell的配置给他报bug(甚至是提交补丁),那你就是考虑到了他没有考虑到的问题,至少在这个问题上你就超过他了,日积月累成果就非常可观了.

    4 增加社区更上一层楼

    假设要充分利用社区,最重要的是专一.

    比如在Quora.com上有非常多有趣的话题.我会节制自己的兴趣,不去定阅和Emacs无关的话题.

    4.1 google plus 的 Emacs 社区

    Google Plus 的 Emacs 社区 在此时Geek 的气场很强,讨论的贴子质量很高.我上过许多大众和小众的 Emacs 社区,这是我的经验之谈.比如,我增加了 Linkedin 和 Facebook 的 Emacs 社区,眼下都退出了.并非这些社区不够专业,仅仅是 Google Plus 讨论问题的技术层次比較高.

    假设你仅仅能增加一个网络社区的话,那么就是 Google Plus 了.

    4.2 GitHub 是 geek 云集的地方

    GitHub 的版本号控制服务非常好.如今它的社区化倾向越来越强了,我喜欢.

    比如,能够看一下 https://github.com/search?p=1&q=stars%3A%3E20+extension%3Ael+language%3Aelisp&ref=searchresults&type=Repositories 上最酷的 Emacs 插件.

    4.3 Emacs牛人的博客

    最好的是Planet Emacsen,多个Emacs博客的集合.

    4.4 Quora.com

    我偏爱的是"列举Emacs中最实用的命令"之类的详细问题.非常多回答拓宽了我的眼界.即使我已相当精通Emacs.

    那种"怎样掌握Emacs"的问题,人人都能插上一脚.即使有些高水平的的回答,也淹没在众多平凡的回答中.

    即使你的问题是比較泛泛而谈的,从一个可以測量的水准的详细问题入手找到高手,然后看高手是怎样回答那些比較泛泛而谈的问题的.

    4.5 在 twitter 上以 "emacs :en" 定期搜索

    twitter 人多,更新结果快.之所以加上":en"是由于有非常多日文内容,我不懂日文.

    4.6 在 stackoverflow 上搜索 emacs 相关的讨论

    google "emacs-related-keywords site:stackoverflow.com"

    我会定期搜索,相同的帖子重复精读.由于 stackoverflow 上的讨论质量非常高.

    4.7 到 Youtube 上看 emacs 相关的视频

    比如,我就是看了 Google Tech Talks 上这个 Org-mode 作者的介绍 而爱上 org-mode.

    注意,Youtube 搜索的结果是最佳匹配的.问题是关于 Emacs 的视频并不太多,假设依照 Youtube 的算法,我每次搜索看到的总是那几个录像.所以假设关注重点是看看 Emacs 社区有些什么新东西的话,默认搜索结果应以时间排序.

    5 阅读是最有效的学习方式

    5.1 EmacsWiki

    EmacsWiki 是一个社区维护的 Emacs 文档,能够觉得是最酷插件和最佳实践的集合点.

    有人抱怨EmacsWiki文档太乱了,质量也參差不齐.对于前者我也有同感.对于后者我不赞同.EmacsWiki的文档质量相当高,因其是唯一由社区维护的半官方的文档.耐心忍受其乱中有序的现状吧.

    读EmacsWiki的最佳方法是,选定一个特定主题,从头读到尾.这样你对特定主题的最新进展都了解了.是否要採用EmacsWiki的建议另当别论.

    5.2 Emacs Lisp 书籍推荐(可选)

    <Writing GNU Emacs Extensions by Bob Glickstein>是Elisp编程书籍中最好的.生动,样例丰富.作者明显是高手,而且用心安排了书的结构.比如,他非常早就介绍了 defadvice 的使用方法.我非常认同这点,defadvice 是 elisp 语言的精华.

    Xah Lee 提供 付费 Emacs Lisp 教程 也相当不错.

    5.3 Steve Yegge的Emacs Lisp教程

    他的Emergency Elisp非常不错,由于非常简洁.我特别喜欢"Statements"一章.

    6 知识管理

    决不要低估长期的自我管理的累积效应.

    我常常看到有人在网上悲伤地抱怨说由于重装电脑,几年积攒的emacs配置都丢失了.也有人自豪地宣称把自己的.emacs主动干掉,为的是弄一个组织的更好的配置.

    你的技巧是成指数增长的,知识积累的越多,这些知识之间的联系就会越多.这些联系增长的速度是以指数的方式增长的.把你emacs配置从头来过,意味着你的积累的知识书面记录丢失了.损失是非常大的.

    所以我建议决不要丢弃你的Emacs配置.

    这也是后文我谈到的为什么要用工具保存emacs配置和相关知识.

    6.1 emacs 配置纳入 github 的版本号控制

    我的配置见 https://github.com/redguardtoo/emacs.d.

    版本号控制能够是觉得一个集中式的知识管理,不论什么时刻不论什么地点对 Emacs 配置的改动都要及时上传和合并 (merge).这点对于个人能力的长期积累非常重要.

    共享Emacs实际也是一种利己的行为,有非常多人使用我的配置,等于帮我測试.

    6.2 将 emacs 相关资料 (如电子图书,博客文章) 备份

    我将全部 Emacs 相关资讯都放在 dropbox 的server上,这样资料就同步到我的智能手机和我的平板电脑上,我能够充分利用空暇时间学习.

    点击这里注冊 dropbox 帐号.注意,dropbox client全然能够在国内使用,尽管訪问其首页可能有点问题.

    我还写了很多博客文章.这些文章都存在org格式的文件里.最后公布的静态博客也纳入版本号控制,參见http://github.com/redguardtoo/blog.binchen.org.

    7 Emacs第三方插件推荐

    Emacs第三方插件非常多.刚開始学习的人的问题是装了太多插件,插件的管理成了问题.

    我建议一開始选择插件的原则应该少而精,被最棒的插件培养出了品味后,可自由挑选适合的插件.

    我推荐插件标准例如以下:

    • 高品质
    • 常常更新
    • 功能强大

    全部插件都能够通过Emacs的包管理器下载.

    下面是插件清单:

    名称 说明 同类插件
    evil 将 Emacs 变为 vi viper
    org org-mode,全能的 note 工具 不知道
    org2blog 给 wordpress 写博客 不知道
    company-mode 自己主动完毕输入,支持各种语言和后端 cedet,auto-complete
    expand-region 按快捷键选中当前文本,能够将选择区域扩展或者收缩 不知道
    smex 让输入 M-x command 变得飞快 不知道
    yasnippet 强大的文本模板输入工具 不知道
    flymake-xxxx 以 flymake 开头的全部包,针对不同语言做语法检查 flycheck
    helm 选择和自己主动完毕的框架,在其上有非常多插件完毕详细功能 ido
    ido 和 helm 类似,我是 helm 和 ido 同一时候用 helm
    js2-mode javascript 的 major-mode,自带 javascript 语法解释器 javascript-mode、js-mode、js3-mode
    w3m Emacs 的网络浏览器(需安装命令行工具w3m) 不知道
    elnode elisp 写的 Web server 不知道
    smartparens 自己主动输入须要成对输入的字符如右括号之类的字符 autopair
    window-numbering.el 跳转到不同的子窗体 不知道
    web-mode 支持各种 HTML 文件 nxml-mode、nxhtml-mode、html-mode

    8 Emacs 是一种生活方式

    假设你照着我以上的做法做,就能够认识到 Emacs 牛人其它也非常牛.Emacs 实际上体现了牛人的一种生活方式.

    像那些牛人一样思考,像那些牛人一样做事,不要怀疑,不要犹豫,非常快你就会发觉自己也開始有些牛人的气质了.

    比如,Sacha Chua 就是这样一个有牛人气质的女孩,这是她的 Youtube 录像. 她学习 Emacs 的方式是 让 Emacs 自己主动将手冊语音合成,这样她在房间里走来走去的时候也能够听文档了.

    想想看,这些用 Emacs 的人都是什么样的 Geek 啊!所以,我觉得 Emacs 不不过一种工具,它是个社区,一种文化.

    对我而言,增加 Emacs 社区让我学会了谦卑.当我明确了 Emacs 的其朴素的设计思想和其强大的可拓展性后,我的感觉是敬畏,由于我做不出这种软件.

    我既没有能力把一个编辑器设计成一个人工智能语言 Lisp 的平台,也不可能花 30 多年的时间对一个软件精益求精.

    9 答疑

    9.1 Steve Purcell 的配置是否有文档能够參考?

    除了 README 外没有,我主要是通过看 EmacsWiki 和源码来了解.一个窍门是通常主源码文件的头部有使用指南.

    9.2 Steve Pucell 的 Emacs 配置需执行 Git 和 subversion,有没有更简单的配置?

    那么你能够用 我的配置

    • 去掉了 Git 和 subversion 的依赖.你仅仅要下载我的配置,确保网络 OK(因第一次启动 Emacs 会自己主动下载安装软件包).
    • 已安装了拼音输入法 eim
    • C++ 支持强大,因我还做一些桌面开发

    注意,Purcell 是顶尖的 Web 开发人员,他会试用各种最新的 Web 开发技术,假设你用了我的配置,Web 开发插件更新会滞后一段时间.另外我的开发工具链和 Purcell 的不全然一致.你自己权衡了.

    9.3 该使用Emacs的哪个版本号

    眼下的最新的稳定版是Emacs 24.3.1,建议不要有用高于这个版本号的Emacs.通常你不用操心版本号号的问题.主流的Linux发行版会帮你处理这个问题.

    9.4 我已是 Vi 高手,为什么要转到 Emacs 来?

    嘿嘿,我也是 Vi 精通后转到 Emacs 的.我转换阵营的原因就是由于 Emacs 的强大 (比如和 gdb 的完美结合) 以及其脚本语言是 lisp.

    当然 Vi 的多模式编辑和快捷键比 Emacs 要高效得多,所以最佳方案是 Vi 的快捷键加上 Emacs 的强大.

    眼下我在用 evil-mode,在 Emacs 下模拟 Vim 操作,结合了两者的长处.简单地说,如今我的执行模式"神用编辑器之神 ".

    警告,Steve Purcell 和我默认都启用了 Vim 的快捷键,假设你不习惯的话,能够打开 ~/.emacs.d/init.el,将当中对应的一行凝视掉,详细凝视哪一行请參考 README.

    9.5 我对于 Emacs 的默认快捷键非常不习惯,怎么办?

    Emacs 的快捷键是经过几十年考验相当高效的,我建议你在未成为高手前还是学习 Emacs 的默认快捷键.

    假设一定要在 Emacs 下用 Windows 快捷键的,能够考虑 ergoemacs.

    9.6 Emacs 快捷键太多记不住怎么办?

    没有必要记快捷键,我也仅仅能记住经常使用的十几个快捷键.顺其自然,经常使用的命令你自然会记住快捷键,过一段时间不用了,又会忘掉,这非常正常.

    眼下非常多高手在用 Smex,能够飞快输入命令,非常多快捷键实际上不须要了.

    9.7 使用牛人的 Emacs 的配置后,发觉界面有些奇怪的 bug,怎么改?

    不要改! 參考上文 站在巨人的肩膀上 一章,你觉得奇怪可能是由于缺乏经验,把某些特性误觉得是 bug.请坚持至少一年.

    比如,有人向我反映,在编辑不论什么文本的时候,会发觉右边约第 80 列处总有一竖线,希望能去掉.这实际上是一特性,提醒你每一行不要宽度不要超过第 80 列.这里是 每行不要超过 80 列的原因.

    我建议你学习 Emacs 的第一年的原则应是,理解而不推断.

    9.8 已按指示下载更新软件包,可是好象没有不论什么作用,也没有不论什么错误信息

    删除 home 文件夹下的 .emacs、~/.emacs.d/init.el 就是代替原来的 .emacs.

    9.9 我有不论什么关于怎样配置 Emacs 的详细问题

    • 读官方教程
    • 善用 google 和我提供的信息

    比如,问:在 .emacs.d 中的 init.el 文件起什么作用?答:google "emacswiki init.el".

    9.10 使用牛人的配置后启动 emacs 报错,怎样解决?

    首先确认你已装上了 你须要的 第三方命令行工具,这些工具是可选的,清单见 我的.emacs.d的README.

    假设排除了以上原因. 又一次启动 emacs,带上 "–debug-init" 參数,然后将显示的错误信息及环境报告到你所用的.emacs.d相应的开发人员# .

    报告 bug 应该给出细节.比如非常多读者给我的 bug 都是因为第三方插件版本号较新引起的,我拿到版本号号后,才干下载特定版本号的插件以重现 bug.否则仅仅能靠猜,来回邮件会浪费读者非常多时间.

    9.11 牛人的 Emacs 配置太复杂,不easy掌控,还是我自己从一个简单的 .emacs 改起好控制

    那么你就是走我懊悔莫及的老路,一个人在黑暗中摸索.开头兴致非常高,但现实是残酷的,碰到复杂问题解决不了.于是选择逃避,最好的借口是 Emacs 太复杂,放弃 Emacs.

    我终于醒悟过来,走上了光明大道,非常多走上岐路的人恐怕就没有这个觉悟和毅力了.

    希望自己掌控坦率地说是一个非技术问题,由于没有自信心,所以有一种补偿心里. 希望通过一种错误的方式来证明自己.结局无非是恶性循环.

    正确地方法是放下身段至少一年 (我已重复强调这一点),打好基本功,读书,虚心地向高手学习.

    让我举一个样例说明:有一个读者向我反映他用了 purcell 的配置,可是 Lisp 的环境花了三天时间也搞不定.尽管我对除 Elisp 以外的其它 Lisp 方言毫无经验,还是花了 15 分钟帮他攻克了这个问题.解决方法非常easy,就是 指定一下用哪个 Lisp 解释器.

    解决该问题须要的基本功非常easy:

    • 知道管道 (pipe),stdout、stderr 是什么.这是 Linux 下做系统开发最最主要的知识.
    • 读文章一开头推荐的官方 Emacs 教程,知道怎样使用在线帮助.我解决该问题的关键也就是把文档读了一下,文档中已经清楚地说明怎样设置 Lisp 解释器
    • 知道怎样 Google.我知道要设置的变量名后,代码懒得写,直接以变量名搜到对应代码 (一行而已),拷贝粘帖.

    9.12 为什么我用了牛人的配置后自己额外加入的插件无效

    Emacs 是个开放平台,其众多插件 release 之前并不一定有严格的測试.所以插件之间可能有冲突.

    这也是我为什么建议刚開始学习的人直接使用牛人配置的原因,由于牛人已经攻克了众多兼容性的问题,你仅仅要直接享受他的服务即可了.

    即使你发觉了牛人尚未来得及处理的 bug,最有效的方法是提交 bug 报告给牛人,而不是自己去钻研 elisp.

    9.13 我想用 Windows 版本号的 Emacs 而不是 Cygwin 版本号的 Emacs,怎么做?

    须要对主要的命令行操作有一定的熟悉.关键知识点有两个:

    1. 设置 HOME 环境变量,由于 .emacs.d 中的某些 elisp 脚本假定 .emacs.d 在 HOME 所相应的路径中.
    2. Emacs 的某些功能须要使用第三方的命令行工具,这些工具的路径应该加入至环境变量 PATH 中 (可选,原因见后面).
    3. 替代步骤 2 的还有一更好的方法是使用第三方插件将 Windows 版本号的 Emacs 和 Cygwin 的工具和 文档 完美结合,參考 我 (redguardtoo) 在 stackoverflow 上的回答.只是须要很多其它的配置.

    假设你不知道怎样在 Windows 下加入改动环境变量,不知道怎样安装第三方工具,建议还是先用 cygwin 中的 Emacs,由于 cygwin 已自带某些工具,没有的话,安装也和方便.且在 cygwin 下环境变量 HOME 默认已有.

    第三方命令行工具清单请參考上文 我的.emacs.d 中的 README(Steve Purcell 没有列出这些工具,因他仅仅用 OS X).

    9.14 Emacs 在代码跳转和代码自己主动完毕上和商业的 IDE 还是有差距,有什么解决方式?

    这个差距说究竟是后端语法解析引擎的问题.坦率地说通常人们问我这个问题都是以微软的 Visual Studio 和 Eclipse 作为參照对象的.

    就 C++ 来说眼下有使用苹果公司的 clang 的方案,效果还不错.就 Java 来说,有使用 eclipse 做为后端引擎的方案.详细使用什么 Emacs 插件来调用这些引擎有非常多选择,不展开了.

    实战中,我通常就是使用 ctags 或者 etags 作为后端引擎,因其全部语言通吃. 尽管解析效果差一点,可是通过我遵循恰当的命名规范,对编程效率没有什么影响.

    使用 ctags 或者 etags 还能够帮助菜鸟程序猿改掉一个非常严重的毛病.菜鸟由于缺乏自信心和经验,所以变量和函数名的命名通常都过于通用,给自己是架构师在写一个大型的通用 Framework 的幻觉.这对于真实的产品研发来说是一个非常严重的问题,想象你要改动某个接口的全部调用,定义,文档和測试案例,而且这个接口在多个语言中都有使用.这个接口假设有一个通用的名字如 list,是会把维护人员气死的 (我以前碰到过一朵奇葩,他还有喜把变量名和函数名叫全然一样名字的"好习惯 ").叫 ListMySpecificService 则好的多.使用 ctags/etags 这类比較弱的解析引擎就会逼你起一个不那么普通的名字.

    假设ctags已不能满足你的需求,你能够考虑用cscope或者Gnu Global (gtags).

    以上我讨论的都是后端引擎的问题.

    就前端界面来说,做的比較好的是company-mode,眼下维护也非常活跃,你能够就特定语言怎样配置company-mode咨询其开发人员.

    9.15 为什么 Emacs 启动时从server (elpa) 安装第三方软件包 (package) 会失败?

    请启动 Emacs 后,执行 `M-x package-refresh-contents` 以从server更新最新的软件索引,然后重新启动 Emacs 就可以.

    假设你没有使用 Emacs 24,而且没有全然拷贝高手的配置 (这是本文的中心思想),那么你须要安装配置 package.el,细节请參考 这里.

    Emacs 下载软件包 (package) 是通过 http 方式,所以假设网络出问题的话你须要用 http 代理server,详细操作见后文.

    9.16 有些站点 Emacs 訪问不了 (原因你懂得)

    在命令行中启动 Emacs 时加上 "http_proxy=your-proxy-server-ip:port" 前缀.

    比如,

    http_proxy=http://127.0.0.1:8000 emacs -nw
    

    9.17 有些软件包下载不下来,也不会用代理

    那么就仅仅能使用我的Emacs配置.

    和我的配置配套的是我建立的独立的第三方包服务,请參考其主页上的README设置.

    9.18 掌握 Emacs Lisp 是否是成为 Emacs 高手的必要条件?

    否.但 Emacs Lisp 是非常强大的语言,其特点是一切皆可改动.当我说"一切"的时候,我就是指字面意义上的"一切",并非修辞上的夸张.

    我用过很多编辑器,除了 Emacs 外,没有一个能做到"一切都可改动"这点 .vi 也不行.

    所以学点 Lisp 对于你提高 Emacs 的使用水平没什么坏处.另外 Lisp 是种不错的语言,假设你的职业是 IT 的话,Lisp 值得一学.

    顺便说一下,Lisp 是种非常easy的学的语言,比 VB easy多了,一旦你适应其语法后,就会发觉它事实上对程序猿蛮友好的,至少少打非常多字.

    9.19 早点学习 Emacs Lisp 是否有助于早日成为 Emacs 高手?

    否,仅仅会起阻碍作用!

    Lisp语法和通常的编程语言有些不同,除非有相当编程经验(至少10年),一般人刚開始都会对其有语法有一点点负面情绪(当然都是毫无道理的偏见).我的意见是学习不论什么新东西,长期来说兴趣是最重要的.一開始就应该避免不论什么会消减兴趣的不论什么负面情绪.

    Emacs Lisp又是一种仅仅用于Emacs的语言,有大量的Emacs相关的术语须要掌握.如"Buffer","Yank","font face",这些术语仅仅有在你成为有相当经验的Emacs使用者后才干理解.

    所以在 Emacs 没有相当基础前学习 Emacs Lisp 是在浪费时间.

    參考前文关于找到切入点的一节,我推荐的学习 Lisp 的顺序是,先使用优秀的 Emacs 配置享受到 Emacs 的优点,有了兴趣后学习 Emacs Lisp 就水到渠成了.

    9.20 Emacs 基本操作我会了,下一步学些什么比較迷茫

    关键是你打算用 Emacs 这个强大的瑞士军刀做什么.

    我在前文中已经强调过以兴趣和解决实际问题作为切入点.

    再举一些我自己的样例说明:

    • 我有写博客须要,懒得用 wordpress 那个破界面,所以用 org2blog
    • 开发 ruby on rails 程序须要 IDE,装了 rinari
    • 做跨平台 C++ 桌面开发,装了 cmake-mode.
    • 我要开发巨型项目 (须要在多个文件夹窗体间跳来跳去),所以装了 window-numbering.el.
    • 巨型项目须要我同一时候调试多种语言,所以我装了 evil-nerd-commenter,这样不用记住特定语言的语法就能够 comment/uncomment 代码.

    9.21 org-mode 该怎样学习?

    Org-mode简明手冊 是不错的中文教程.

    我觉得最好的英文新手教程是Carsten Dominik(org-mode发明者)在google tech talks上的演讲.其要点为org-mode本质是一个文本文件,你仅仅要记住按TAB展开或者缩进条目就能够了.其它高级特性能够慢慢学.

    9.22 对于"一切都用Emacs来完毕"的观点你怎么看?

    我非常赞赏这个理念.可是不要走火入魔.Emacs本质是个平台,给geek们提供了无限的可能性.

    可是从有用角度讲,Emacs和其它工具结合有时候能更快完毕工作(只是菜鸟在没有一年的修炼之前千万不要猜Emacs*不能*做什么).

    下面是我觉得不一定Emacs可以吃独食的地方:

    • 剪贴簿操作应结合命令行工具xsel(Linux)/pbpaste(OSX)/putclip(Cygwin)
    • Web浏览最好用Firefox结合插件如keysnail
    • 远程登录管理最好用screen/tmux
    • FTP最好用专门的FTP软件
    • 文件管理用专用软件

    原因多种多样,比方远程ssh登录使用Emacs的话,Emacs默认假定你是不能訪问X clipboard的,可是这个假定如今不成立,假设你使用X11 forward over ssh技术(主流的Linuxserver默认都支持的),剪贴板是能够訪问的.

    所以重点是保持头脑灵活,坚信Emacs无所不能的同一时候也要适当变通一下.

    10 联系我

    这是我的 twitter google plus 以及 微博,也能够通过我的 email<chenbin DOT sh AT GMAIL DOT COM>联系我.我也在新浪 weibo.com 上开通账号 emacsguru.

    我的主力博客为 http://blog.binchen.org.

    我不会回答 Emacs 配置的详细问题,由于假设你通读本文,应该知道哪里找答案更好.

    11 结语

    在本文结束时,我再强调一下本文最重要的观点.

    要点是:

    • 以*基于解决实际问题*产生的兴趣引导
    • 全然照抄*世界顶尖高手*如Steve Purcell的配置,尽量避免研究自己怎样配置Emacs,当然也尽可能少写Elisp代码.
    • 学习Emacs和学习不论什么一种专业技能(拉小提琴,解数学题)的方法论都是一样的,请參考 一万小时天才理论.

    关键是你以严肃的态度把其当作专业技能学习. 非常多人之所以不赞同我的核心观点可能是由于在他们的内心深处还是有把Emacs用来炫耀"我有多酷"的意识.

    Emacs当然非常强大,能够作为一种另类娱乐工具来博得眼球.可是它的本质是为专业人士使用的神器.

    让我打个例如,职业杀手对于杀人的刀仅仅关心两件事:

    1. 高效地杀人
    2. 不论什么环境下都可靠

    刀的装饰是否美丽或者用刀技巧是否是自己原创的对职业杀手并不重要.

    Emacs就是那把刀.

    11.1 怎样报bug

    本文已放在 GitHub 上,网址为 https://github.com/redguardtoo/mastering-emacs-in-one-year-guide.

    假设有不论什么疑问,请在以上网址报 bug.这比 Email 要快.因GitHub会以邮件通知我,GitHub 邮件永远归类至我的最优先目录下.

    假设直接给我发 Email,就会淹没于垃圾邮件中.

    11.2 不要复制粘帖本文

    Emacs 本质上是一个社区和平台,不断有新的有趣的人和技术出现.我会定期更新本文.

    假设你仅仅是拷贝粘帖全文,会使你自己和他人错过更新.

    我建议你最好分享本文的链接,

  • 相关阅读:
    随机数生成程序代码( 伪随机<stdlib.h> )
    C++的学习 (此博客将一直补充更新下去,C++语法方面的内容不开新随笔了, *【语法学习】)
    sdut oj 1510 Contest02-4 Spiral
    POJ 2017 Speed Limit (直叙式的简单模拟 编程题目 动态属性很少,难度小)
    JavaWeb-入门第一课-1.静态web动态web 2.web服务器 3.下载和安装Tomcat-web服务器
    java小知识,驼峰规则
    亚马逊 协同过滤算法 Collaborative filtering
    第一个JSP程序
    物理学步入禅境:缘起性空
    人既然知道努力就可以进步,为什么还是会不努力?
  • 原文地址:https://www.cnblogs.com/mfrbuaa/p/3899153.html
Copyright © 2011-2022 走看看