Atitit.ide技术原理与实践attilax总结

1.1. 语法着色1

1.2. 智能提示1

1.3. 类成员outline..func list1

1.4. 类型推导(type inference): 1

1.5. Remote debug1

1.6. debugging api包一个gui就够了 1

1.7. expression evaluation 2

1.8. 如Java Compiler API2

1.9. Ide每部分代码数统计3

1.1. 语法着色

语法高亮要靠parser,跳转到定义处编译器要提供symbol和源码位置字典,重构编译器要重写ast, 要支持调试窗口里运行表达式甚至直接调用函数,这个要运行时支持。编译

1.2. 智能提示

1.3. 类成员outline..func list

1.4. 类型推导(type inference):

1.5. Remote debug

,attach上去调

1.6. debugging api包一个gui就够了

1.7. expression evaluation

这种黑魔法一样的东西(仅针对编译型语言这么说,解释型应该会容易很多),当初应该花了大量的精力开发;

作者::  ★(attilax)>>>   绰号:老哇的爪子 ( 全名::Attilax Akbar Al Rapanui 阿提拉克斯 阿克巴 阿尔 拉帕努伊 ) 汉字名:艾龙,  EMAIL:1466519819@qq.com

转载请注明来源: http://blog.csdn.net/attilax

1.8. 如Java Compiler API

我主要关注的是编译器,所以下面就编译器与IDE多聊几句。

当然,现实中开发一个IDE还真的有可能得去实现源语言的编译器。

上面提到的SharpDevelop/MonoDevelop,目前新的版本已经改为基于微软的Roslyn编译器来提供C#支持,语法高亮、错误提示、智能提示等都做得很好了。但其早期版本其实非常弱,只有所谓“语法高亮”,可以参考这个文档。后来为了实现智能提示等功能总算决定实现个真正的C# parser。不过它并没有基于任何现成的编译器来支持IDE功能,而是自己写了一个,上面的书中第12章就是介绍这个parser的,不过写得有点乱嗯。

以Eclipse的Java开发环境(JDT)为例,它要实现准确的语法高亮和语法错误提示,就得按照Java语法实现一个完整的parser;它要实现实时的语义错误提示,就得按照Java语义实现一个完整的语义分析器,而且为了良好的用户体验,它可能要内建更多的对错误模式的检查和提示。做到这里,离一个完整的Java源码编译器也就只剩一个很简单直观的代码生成器(code generator)了。于是Eclipse做了ECJ——Eclipse Compiler for Java,整合在Eclipse JDT中。
在此基础上,Eclipse JDT还有项目模型,将项目里的各种资源都用一个统一的模型管理起来,从workspace到project、package、file然后里面的class/interface这样一直下去。在class/interface层面上这个模型用的就是ECJ的AST。

其实如果有一个现成的对IDE支持良好的编译器的话,实现一个IDE就不必费那么多事自己去写编译器。但是Eclipse诞生时,主流的Java源码编译器javac并不开源,而IBM当时主流的Java源码编译器Jikes是用C++写的,要整合在用Java写的Eclipse里不太方便,所以才要自己写。
有了这个编译器之后,Eclipse倒是可以做许多“非常规”的事情。例如说它可以为有错误的源码文件生成Class文件,而且这个Class文件可以一直执行到源码里有错的地方然后抛出异常——这种事情javac就不太可能会去做。

后来javac开源了,而且开放出许多便于IDE实现自身功能的API出来(例如Java Compiler API),后来的Netbeans就干脆直接用javac来实现语法高亮、报错等各种功能了。背后的故事可以参考这篇博文:NetBeans IDE 6.0

而一个反例就是微软的Visual Studio里的C++支持。Visual C++自身是个优秀的优化编译器,但它的前端部分(词法/语法/语义分析+中间代码生成)的历史非常非常“久远”,原始设计并未考虑支持IDE的功能,所以Visual Studio IDE里的C++支持其实用的是另一套完全不同的C++ parser(购买自EDG),既增加了复杂度又无法保证两套parser之间完全的兼容性。
当然微软也早就意识到了这个问题。近来,随着对C++14的支持,微软大幅更新了其Visual C++编译器的前端(参考Rejuvenating the Microsoft C/C++ Compiler),按照这个路子走下去的话,在IDE里替换掉EDG的C++ parser改为直接用Visual C++自己的,兴许也是可能的未来。

1.9. Ide每部分代码数统计

分类

包含内容

源码行数

Code Analysis

代码模型、分析和生成相关

123957

IDE

IDE程序和界面相关

62940

Visual Editor

可视化编辑器

30760

Text Editor

文本编辑器

20264

Tools

版本控制和帮助等辅助工具

11556

Language

语言绑定,包括C#,VB等

9292

Debugger

调试器

9238

Framework

Asp.Net Mvc等框架支持

8513

Misc

杂项

2289

Builder

构建和MsBuild相关

1774

Data

数据库支持

1396

对应的图表:

项目分析

可见整个IDE最复杂的部分在于代码模型的处理,代码数量几乎是第二名(IDE)的两倍之多,占整个项目代码的比例也接近 50% 了。我没有进一步分析,不过大概可以想象,代码编辑时的文本着色、语法提示、代码生成、辅助分析、重构等功能应该都与此相关。如果真的想自己写一个IDE的话,这一部分肯定是个难啃的硬骨头。

参考资料

IDE的现实分析 - 对“开发一个IDE难度有多大”问题的回答 _ Shuhari的博客.html

开发一个IDE难度多大_ - 编程 - 知乎.html

Atitit.ide技术原理与实践attilax总结相关推荐

  1. Atitit.软件兼容性原理与实践 v3 q326.docx

    Atitit.软件兼容性原理与实践 v3 q326.docx 1. 架构兼容性1 2. Api兼容性1 2.1. 新api  vs  修改旧的api1 3. Web方面的兼容性(js,html)1 3 ...

  2. Atitit 《控制论原理与概论attilax总结

    Atitit <控制论原理与概论attilax总结 <控制论> 奠基之作,出自创始人维纳.虽然内容权威,但我认为带有相当强烈的个人色彩,且门槛较高,不适合入门.深入研究控制论必看书籍 ...

  3. 【java】Java 动态调试技术原理及实践

    1.概述 转载:Java 动态调试技术原理及实践 一.动态调试要解决的问题 断点调试是我们最常使用的调试手段,它可以获取到方法执行过程中的变量信息,并可以观察到方法的执行路径.但断点调试会在断点位置停 ...

  4. 【Spark】Spark SQL 物化视图技术原理与实践

    1.概述 转载:Spark SQL 物化视图技术原理与实践 2.导言 本文将基于 SparkSQL(2.4.4) + Hive (2.3.6), 介绍物化视图在SparkSQL中的实现及应用. 3.什 ...

  5. 干货:服务器网卡组技术原理与实践

    摘要:证券行业为了保障其业务的高可用性,数据中心服务器接入大量采用了服务器网卡(Team)技术.Team技术不完全属于网络系统,也不完全属于主机系统负责,而是介于两者的中间地带,因此极易出现问题.最常 ...

  6. 解密“达达-京东到家”的订单即时派发技术原理和实践

    本文由达达京东到家Java工程师季炳坤原创分享. 1.前言 达达-京东到家作为优秀的即时配送物流平台,实现了多渠道的订单配送,包括外卖平台的餐饮订单.新零售的生鲜订单.知名商户的优质订单等.为了提升平 ...

  7. 百分点认知智能实验室:智能校对的技术原理和实践

    编者按 :大数据时代下各种文本信息爆炸,传统的文本分析处理工作逐渐被计算机取代.文本数据量越大,其中所包含的错误的总数也越多,通过校对工作来纠正文本中的错误显得尤其重要.传统的校对主要依赖人工,通过人 ...

  8. Java 动态调试技术原理及实践

    调试是发现和减少计算机程序或电子仪器设备中程序错误的一个过程.最常用的断点调试技术会在断点位置停顿,导致应用停止响应.本文将介绍一种Java动态调试技术,希望能对大家有帮助.同时也欢迎读者朋友们一起交 ...

  9. 2MyBatis入门--深入浅出MyBatis技术原理与实践(笔记)

    什么是 MyBatis ? MyBatis 是支持定制化 SQL.存储过程以及高级映射的优秀的持久层框架.MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集.MyBatis ...

最新文章

  1. python编程入门指南磁力下载-使用python 将bt转磁力链接
  2. 【转】pDc-SelectObject(pOldBrush)恢复画刷
  3. Visual Leak Detector 帮助检查内存泄露
  4. 牛客-139 I. Substring(后缀数组 or 后缀自动机)
  5. smarty5变量修改器
  6. python内存管理可以使用del_Python深入学习之内存管理
  7. 飞鸽传书2014提前发布?
  8. android 方法统计,Android 利用编译时 注入 统计App内所有方法执行时常,分析ANR
  9. mysql 密码忘了_mysql8.0以上版本安装配置及忘记密码时重置
  10. 凯西·奥尼尔:盲目信仰大数据的时代必须结束 | 算法密码
  11. c语言图书管理系统报告书,c语言图书管理系统实验报告_c语言程序设计报告 图书管理平台_c语言 图书管理平台...
  12. 查看计算机本机IP地址,本机ip地址查询
  13. 用js把数字转化成为大写金额
  14. excel概率密度函数公式_标准正态分布密度函数公式
  15. 快递单用什么打印机比较好?
  16. 解决windows下无法ctrl+A全选数据快捷键的问题
  17. PDF压缩文件怎么压缩最小?用迅读PDF大师,一键无损压缩
  18. JQuery冒泡(选择并上传多张图片)
  19. PixelUtils:像素转换工具
  20. Imperva常用的维护命令

热门文章

  1. 塞尔达传说gba_《塞尔达传说缩小帽》是系列一年级生?,回忆众多玩友的启蒙之作...
  2. python同花顺交易接口_开启量化第一步!同花顺iFinD数据接口免费版简易操作教程...
  3. linux ssh环境,在Linux下ssh 环境的登录 和 文件拷贝
  4. php提交失败阻止提交数据,php – 在刷新浏览器时阻止重新提交提交
  5. Spring Cloud Eureka 最简入门示例
  6. 1.1 版本控管与Git
  7. [过年菜谱之]清蒸鲍鱼
  8. UTF-8的BOM头
  9. asyncdata 获取参数_nuxt的asyncData发送post请求如何传递FormData形式的参数
  10. Python 包管理工具poetry配置国内PyPI镜像源