阅读更多

0顶
0踩

研发管理

转载新闻 无谓的编辑器之争

2013-05-21 10:02 by 副主编 WnouM 评论(5) 有8581人浏览
本文转载自王垠的博客,作者在文中讨论了由来已久的编辑器之争,并给出了自己的解决方案——IDE以及结构化编辑器。


无谓的编辑器战争

很多人都喜欢争论哪个编辑器是最好的。其中最大的争论莫过于 Emacs 与 vi 之争。vi 的支持者喜欢说:“看 vi 打起字来多快,手指完全不离键盘,连方向键都可以不用。”Emacs 的支持者往往对此不屑一顾,说:“打字再快又有什么用。我在 Emacs 里面按一个键,等于你在 vi 里面按几十个键。”

其实还有另外一帮人,这些人喜欢说:“对于 Emacs 与 vi 之争,我的答案是 {jEdit, Geany, TextMate, Sublime...}”这些人厌倦了 Emacs 的无休止的配置和 bug,也厌倦了 vi 的盲目求快和麻烦的模式切换,所以他们选择了另外的更加简单的解决方案。

临时解决方案 —— IDE

那么我对此的答案是什么呢?在目前的情况下,我对程序编辑的临时答案是:IDE。

写程序的时候,我通常根据语言来选择最能“理解”那种语言的“IDE”(比如 Visual Studio, Eclipse, IntelliJ IDEA 等),而不是一种通用的“文本编辑器”(比如 Emacs, vi, jEdit, ...)。这是因为“文本编辑器”这种东西一般都不真正的理解程序语言。很多 Emacs 和 vi 的用户以为用 etags 和 ctags 这样的工具就能让他们“跳转到定义”,然而这些 tags 工具其实只是对程序的“文本”做一些愚蠢的正则表达式匹配。它们根本没有对程序进行 parse,所以其实只是在进行一些“瞎猜”。简单的函数定义它们也许能猜对位置,但是对于有重名的定义,或者局部变量的时候,它们就力不从心了。

很多人对 IDE 有偏见,因为他们认为这些工具让编程变得“傻瓜化”了,他们觉得写程序就是应该“困难”,所以他们眼看着免费的 IDE 也不试一下。有些人写 Java 都用 Emacs 或者 vi,而不是 Eclipse 或者 IntelliJ。可是这些人错了。他们没有意识到 IDE 里面其实蕴含了比普通文本编辑器高级很多的技术。这些 IDE 会对程序文本进行真正的 parse,之后才开始分析里面的结构。它们的“跳转到定义”一般都是很精确的跳转,而不是像文本编辑器那样瞎猜。

这种针对程序语言的操作可以大大提高人们的思维效率,它让程序员的头脑从琐碎的细节里面解脱出来,所以他们能够更加专注于程序本身的语义和算法,这样他们能写出更加优美和可靠的程序。这就是我用 Eclipse 写 Java 程序的时候相对于 Emacs 的感觉。我感觉到自己的“心灵之眼”能够“看见”程序背后所表现的“模型”,而不只是看到程序的文本和细节。所以,我经常发现自己的头脑里面能够同时看到整个程序,而不只是它的一部分。我的代码比很多人的都要短很多也很有很大部分是这个原因,因为我使用的工具可以让我在相同的时间之内,对代码进行比别人多很多次的结构转换,所以我往往能够把程序变成其他人想象不到的样子。

对于 Lisp 和 Scheme,Emacs 可以算是一个 IDE。Emacs 对于 elisp 当然是最友好的了,它的 Slime 模式用来编辑 Common Lisp 也相当不错。然而对于任何其它语言,Emacs 基本上都是门外汉。我大部分时间在 Emacs 里面是在写一些超级短小的 Scheme 代码,我有自己的一个简单的配置方案。虽然谈不上是 IDE,Emacs 编辑 Scheme 确实比其它编辑器方便。R. Kent Dybvig 写 Chez Scheme 居然用的是 vi,但是我并不觉得他的编程效率比我高。我的代码很多时候比他的还要干净利落,一部分原因就是因为我使用的 ParEdit mode 能让我非常高效的转换代码的“形状”。

当要写 Java 的时候,我一般都用 Eclipse。最近写 C++ 比较多,C++ 的最好的 IDE 当然是 Visual Studio。可惜的是 VS 没有 Linux 的版本,所以就拿 Eclipse 凑合用着,感觉还比较顺手。个别情况 Eclipse “跳转定义”到一些完全不相关的地方,对于 C++ 的 refactor 实现也很差,除了最简单的一些情况(比如局部变量重命名),其它时候几乎完全不可用。当然 Eclipse 遇到的这些困难,其实都来自于 C++ 语言本身的糟糕设计。

终极解决方案 —— 结构化编辑器

想要设计一个 IDE,可以支持所有的程序语言,这貌似一个不大可能的事情,但是其实没有那么难。有一种叫做“结构化编辑器”的东西,我觉得它可能就是未来编程的终极解决方案。

跟普通的 IDE 不同,这种编辑器可以让你直接编辑程序的 AST 结构,而不是停留于文本。每一个界面上的“操作”,对应的是一个对 AST 结构的转换,而不是对文本字符的“编辑”。这种 AST 的变化,随之引起屏幕上显示的变化,就像是变化后的 AST 被“pretty print”出来一样。这些编辑器能够直接把程序语言保存为结构化的数据(比如 S表达式,XML 或者 JSON),到时候直接通过对 S表达式,XML 或者 JSON 的简单的“解码”,而不需要针对不同的程序语言进行不同的 parse。这样的编辑器,可以很容易的扩展到任何语言,并且提供很多人都想象不到的强大功能。这对于编程工具来说将是一个革命性的变化。

  • 已经有人设计了这样一种编辑器的模型,并且设计的相当不错。你可以参考一下这个结构化编辑器,它包含一些 Visual Studio 和 Eclipse 都没有的强大功能,却比它们两者都要更加容易实现。你可以在这个网页上下载这个编辑器模型来试用一下。
  • 我之前推荐过的 TeXmacs 其实在本质上就是一个“超豪华”的结构化编辑器。你可能不知道,TeXmacs 不但能排版出 TeX 的效果,而且能够运行 Scheme 代码。
  • IntelliJ IDEA 的制造者 JetBrains 做了一个结构化编辑系统,叫做MPS。它是开源软件,并且可以免费下载。
  • 另外,Microsoft Word 的创造者 Charles Simonyi 开了一家叫做Intentional Software 的公司,也做类似的软件。
  • 大小: 41.7 KB
来自: 王垠的博客
0
0
评论 共 5 条 请登录后发表评论
5 楼 thc1987 2013-05-23 14:51
开发效率啊亲
4 楼 bean-woo 2013-05-23 09:42
有工具不用是SB
3 楼 mathgl 2013-05-21 17:11
white_crucifix 写道
写java的几乎没有多少人会故意避开IDE吧,写脚本语言的程序员倒是不用IDE的很常见。毕竟java相比脚本语言写起来代码会多一点,也容易笔误,总是靠编译来调错翻来覆去也麻烦


用vim, emacs写java很有些行为艺术的味道。。

2 楼 guilipan 2013-05-21 14:39
人们用IDE是为了省时省力偷懒,可是有的人懒到了连IDE都不想装的地步。。。
1 楼 white_crucifix 2013-05-21 10:18
写java的几乎没有多少人会故意避开IDE吧,写脚本语言的程序员倒是不用IDE的很常见。毕竟java相比脚本语言写起来代码会多一点,也容易笔误,总是靠编译来调错翻来覆去也麻烦

发表评论

您还没有登录,请您登录后再发表评论

相关推荐

  • 编辑器与IDE

    装载: 编辑器与IDE无谓的编辑器战争 很多人都喜欢争论哪个编辑器是最好的。其中最大的争论莫过于 Emacs 与 vi 之争。vi 的支持者喜欢说:“看 vi 打起字来多快,手指完全不离键盘,连方向键都可以不用。”Emacs 的...

  • 【转】编辑器与IDE

    无谓的编辑器战争 很多人都喜欢争论哪个编辑器是最好的。其中最大的争论莫过于 Emacs 与 vi 之争。vi 的支持者喜欢说:“看 vi 打起字来多快,手指完全不离键盘,连方向键都可以不用。”Emacs 的支持者往往对此...

  • 王垠:编辑器与IDE

    无谓的编辑器战争 很多人都喜欢争论哪个编辑器是最好的。其中最大的争论莫过于 Emacs 与 vi 之争。vi 的支持者喜欢说:“看 vi 打起字来多快,手指完全不离键盘,连方向键都可以不用。”Emacs 的支持者往往对此...

  • [王垠系列]编辑器与IDE

    无谓的编辑器战争 很多人都喜欢争论哪个编辑器是最好的。其中最大的争论莫过于 Emacs 与 vi 之争。vi 的支持者喜欢说:“看 vi 打起字来多快,手指完全不离键盘,连方向键都可以不用。”Emacs 的支持者往往对此...

  • 一个JAVA码农的Node之旅

    对于开发环境, 青菜萝卜各有所爱, 无论你是使用神的编辑器/编辑器之神, 或是sublime/atom/npp之流, 亦或是WebStorm高富帅有钱任性, 都是很不错的选择。 supervisor 是个好东西, 它可以帮你watch代码变更, 自动重启...

  • 一个Java码农的Node之旅

    对于开发环境,无论你是使用编辑器/编辑器之神,或是sublime/atom/npp之类,亦或是WebStorm高富帅有钱任性,都是很不错的选择。 Supervisor可以帮你watch代码变更,自动重启服务,从而节省了手工重启程序的时间。 ...

  • Java中高级面试题总览(二)

    减少无谓的线程切换。 在NIO中有几个核心对象需要掌握:缓冲区(Buffer)、通道(Channel)、选择器(Selector)。 Buffer实际上是一个容器对象,所有数据都是用缓冲区处理的。在读取数据时,它是直接读到缓冲区中的...

  • 一张图概括编程语言发展史

    一张图概括编程语言发展史 一张图概括编程语言发展史 Intro 编年史 ...它是一种被标准化的交流语言,用来向计算机发出指令。一种计算机语言让程序员能够准确地定义计算机所需要使用...之所以有那么多种不同的编程...

  • 不要困在自己建造的盒子里——写给.NET程序员(附精彩评论)

    真正的程序员肯定不会限定在.net平台,程序员就是为了解放生产力,提高工作效率而生的,其实除.net以外,还有其他很好玩的技术或工具,比如你所说的编辑器之神vim,无论是windows平台还是linux平台,都是其它编辑器...

  • 近年创业目睹之怪现状

    标 题: 近年创业目睹之怪现状 一章 发信站: 水木社区 (Sun Jul 8 23:07:38 2012), 站内 外出取材结束,改了一些不通顺的地方,又更了几千字,算是补写到第一章结束吧。 不出意外,大概每周末写一章,每章字数一...

  • 你必须知道的.NET(第2版)

    对于软件开发者来说,其心态越来越急躁,不愿意踏踏实实静下心来研究一点技术,做几年的开发工作都争着转向管理方面;而对于IT出版业来说,各种粗制烂造的书籍层出不穷,导致软件开发者对国人的书丧失了信心。 让...

  • Emacs 学习笔记一

    何必做这些无谓的口舌之争呢? 记 得还有人说过一句似乎听来是很无奈的一句:Emacs是很优秀,但是UNIX系统还有一些其他的优秀软件,由此我们也可以看出人们对态Emacs的态度. 有人说Emacs本身就是一个操作系统,我们...

  • 基于COMSOL的电磁场与光学仿真:多极分解通用模型探讨石墨烯临界耦合光吸收与费米能级可调性,COMSOL 多极分解,分方向多级展开通用模型,电磁场,面上箭头,透射率光学 BIC 仿真 COMSOL

    基于COMSOL的电磁场与光学仿真:多极分解通用模型探讨石墨烯临界耦合光吸收与费米能级可调性,COMSOL 多极分解,分方向多级展开通用模型,电磁场,面上箭头,透射率光学 BIC 仿真。 COMSOL 准 BIC控制石墨烯临界耦合光吸收。 COMSOL 光学仿真,石墨烯,光吸收,费米能级可调 ,关键词:COMSOL; 多极分解; 分方向多级展开通用模型; 电磁场; 面上箭头; 透射率; BIC 仿真; 准 BIC; 控制石墨烯; 临界耦合光吸收; 光学仿真; 石墨烯; 光吸收; 费米能级可调。,COMSOL多极分解法仿真石墨烯光吸收特性及费米能级调控

  • Matlab Simulink下的单相光伏储能模型:可再生能源发电与蓄电池储能系统建模与仿真,涵盖MPPT电导增量法及并网技术,Matlab simulink模型,单相光伏储能模型可再生能源发电 太阳

    Matlab Simulink下的单相光伏储能模型:可再生能源发电与蓄电池储能系统建模与仿真,涵盖MPPT电导增量法及并网技术,Matlab simulink模型,单相光伏储能模型可再生能源发电 太阳能发电蓄电池储能建模与仿真 可调节光照强度,采用MPPT电导增量法最大功率点跟踪双向DC DC蓄电池储能及补偿。 额定功率2500w,并网等级311v有效值220v ,Matlab Simulink模型; 单相光伏储能模型; 可再生能源发电; 太阳能发电; 蓄电池储能建模与仿真; 调节光照强度; MPPT电导增量法; 最大功率点跟踪; 双向DC DC; 额定功率2500w; 并网等级311v; 有效值220v,基于Matlab Simulink的单相光伏储能模型:MPPT跟踪与蓄电池储能补偿研究

  • 基于springboot的音乐网站与分享平台lw+ppt

    包含项目论文和毕业答辩PPT,详情请看博客:https://blog.csdn.net/2401_87429224/article/details/145231201 论文主要包括以下内容: 1、中英文摘要; 2、目录; 3、绪论,包括背景、意义、开发工具、国内外现状等; 4、系统分析,包括可行性分析、设计原则、需求分析、业务流程分析等; 5、系统设计,包括功能设计、数据库设计等; 6、系统实现,包括各模块实现; 7、软件测试,包括测试环境、测试条件、运行情况等。

  • "图腾柱PFC电路仿真研究:电压电流双闭环PI控制下的动态响应与稳定性验证及主电路设计说明",图腾柱(totem pole)PFC电路仿真,采用电压电流双闭环PI控制 输出特性好 仿真中模拟了给定

    "图腾柱PFC电路仿真研究:电压电流双闭环PI控制下的动态响应与稳定性验证及主电路设计说明",图腾柱(totem pole)PFC电路仿真,采用电压电流双闭环PI控制。 输出特性好。 仿真中模拟了给定电压变化时的动态响应情况。 可验证闭环控制的稳定性。 另也有图腾柱PFC主电路参数的设计说明 matlab simulink plecs等环境 ,totem_pole; PFC电路仿真; 电压电流双闭环PI控制; 动态响应; 闭环控制稳定性; 主电路参数设计; Matlab Simulink; PLECS。,"图腾柱PFC电路仿真与参数设计研究,电压电流双闭环PI控制稳定性的验证"

  • 2025年材料员网络培训考试题库及答案.docx

    2025年材料员网络培训考试题库及答案.docx

  • **Qt CPP多列时间轴控件:事件线发展故事大纲的可视化编辑器**,Qt CPP实现的多列时间轴控件、可与多段字符串格式自由转、也可手动添加列表项、专门用来以时间轴作为事件线发展顺序的故事大纲 时

    **Qt CPP多列时间轴控件:事件线发展故事大纲的可视化编辑器**,Qt CPP实现的多列时间轴控件、可与多段字符串格式自由转、也可手动添加列表项、专门用来以时间轴作为事件线发展顺序的故事大纲。 时间可输入任意内容,不限于时间,每一时间段允许多列,即多个文字节点,行与行、列与列 之间任意拖拽更顺序,可与文字自由转,按需修改快捷键,所有的编辑可撤销,美观的调整动画。 源码: 使用Qt5.13.1_MinGW编译通过。 ,Qt CPP时间轴控件; 多列时间节点; 自由转换字符串格式; 手动添加列表项; 时间轴事件线; 拖拽更换顺序; 快捷键自定义; 编辑可撤销; 动画调整。,基于Qt C++的多功能多列时间轴故事线管理控件

  • 红外解码 红外遥控,个人学习整理,仅供参考

    ===下载后有不懂的可以私信我。==== 红外解码与红外遥控是电子工程领域中常见的一种技术,主要应用于家用电器、智能家居设备以及遥控玩具等。本文将深入探讨这两个概念,并结合"28.红外遥控解码数码管显示实验"这一主题,为你提供丰富的学习内容。 我们要理解红外(Infrared,简称IR)的基本原理。红外是一种电磁波,频率范围在300GHz到400THz之间,位于可见光的红色光谱之外。在遥控系统中,红外通信通常采用的是近红外频段,即约940nm左右的波长。它具有传输距离近、功耗低、抗干扰能力较弱的特点,适用于室内短距离通信。 红外遥控系统由两部分组成:发射器(遥控器)和接收器(解码器)。发射器通常包含一个微控制器和红外LED,用于编码并发射控制信号。这些信号是通过特定的编码方式,如RC5、NEC、SIRC等编码协议发送的,以确保数据的准确性和唯一性。接收器则含有一个红外光电传感器,用于捕捉这些信号并进行解码。 红外解码是接收器的核心功能。当接收到红外信号后,解码器会对其进行解调,然后解析出编码的指令。解码过程包括信号放大、滤波、峰值检测和脉冲计数等步骤。不同的编码协议有不同的解码方法,例如NEC协议的解码需要识别前导码、地址码、命令码和校验码等组成部分。 数码管显示在红外遥控实验中扮演了重要角色。数码管,也称为数字管或七段显示器,可以用来显示数字、字母和一些特殊字符。在红外遥控解码实验中,一旦解码成功,通常会通过数码管将接收到的指令代码或状态信息呈现出来,便于观察和调试。 "28.红外遥控解码数码管显示实验"可能是一个实践项目,旨在帮助学习者亲手搭建一个简单的红外遥控系统。这个实验可能涵盖了以下内容: 1. 硬件搭建:包括红外接收模块、微控制器(如Arduino或AVR)、数码管及其驱动电路。 2. 软件编程:编写微控制器的程序来实现红外信号的接收、解码以及数码管的显示控制。这涉及到对红外解码协议的理解和编程实现。 3. 实验操作:调整遥控器,发送不同指令,观察数码管的反馈,验证解码的正确性。 通过这样的实验,你可以亲身体验红外遥控系统的完整流程,加深对红外解码原理和实践应用的理解。同时,这也是提升动手能力和解决问题能力的良好机会。 红外解码和红外遥控是电子工程师必备的技能之一。掌握这些知识不仅可以让你理解和设计自己的遥控系统,还为进入更高级的嵌入式系统开发打下基础。希望这个资源能对你在红外学习的道路上有所帮助,祝你在探索科技的旅程中不断进步。。内容来源于网络分享,如有侵权请联系我删除。

  • Java毕业设计-springboot-vue-图书个性化推荐系统(源码+sql脚本+29页零基础部署图文详解+38页论文+15页答辩+环境工具+教程+视频+模板).zip

    资源说明: 1:csdn平台资源详情页的文档预览若发现'异常',属平台多文档切片混合解析和叠加展示风格,请放心使用。 2:29页图文详解文档(从零开始项目全套环境工具安装搭建调试运行部署,保姆级图文详解),旨在为更多的人甚至零基础的人也能运行、使用和学习。 3:配套毕业论文,万字长文,word文档,支持二次编辑。 4:配套答辩ppt,pptx格式,支持二次编辑。 5:工具环境、ppt参考模板、相关电子教程、视频教学资源分享。 6:资源项目源码均已通过严格测试验证,保证能够正常运行,本项目仅用作交流学习参考,请切勿用于商业用途。 7:项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通。 内容概要: 本系统基于 B/S 网络结构,在 IDEA 中开发。服务端用 Java 并借 Spring Boot 框架搭建后台。前台采用支持 HTML5 的 VUE 框架。用 MySQL 存储数据,可靠性强。 能学到什么: 使用Spring Boot搭建后台。VUE 框架构建前端交互界面、前后端数据交互、MySQL管理数据、从零开始环境搭建、调试、运行、打包、部署流程。

Global site tag (gtag.js) - Google Analytics