You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

63 lines
7.6 KiB
Markdown

This file contains invisible Unicode characters!

This file contains invisible Unicode characters that may be processed differently from what appears below. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to reveal hidden characters.

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

# 开篇词 | 为什么你要学习编译原理?
你好我是宫文学一名技术创业者。我曾经参与过几个公司的创业过程在开源技术社区也做过一些工作现在是北京物演科技CEO。
我喜欢做平台性的软件而编译技术就是产品取得优势的关键。我是国内最早一拨做BPM的也就是流程管理平台也是最早一拨做BI平台的现在流行叫大数据。当时我们只有3个人用编译技术做了一些硬核的产品原型跟联想集团签订了战略级合作协议。之后我又做过电子表单和快速开发平台而它们的核心就是编译技术。
我参与的第一个公司卖给了上市公司,第二个在新三板上市,这些成果在一定程度上受益于编译技术。而我呢,对编译技术一直很重视,也一直保持着兴趣。所以很高兴能在“极客时间”上分享与编译技术有关的原理和经验,希望我的分享能帮助你在编译技术这个领域获得实实在在的进步。
众所周知编译技术是计算机科学皇冠上的明珠之一。历史上各门计算机语言的发明人总是被当作英雄膜拜。比尔·盖茨早期最主要的成就就是写了一个Basic的解释器。当年Brendan Eich设计的JavaScript虽然语言略微有点儿糙但却顽强地生存到了现在。
很多国外厂商的软件普遍都具备二次编程能力比如Office、CAD、GIS、Mathematica等等。德国SAP公司的企业应用软件也是用自己的业务级语言编写的。目前来看谷歌也好苹果也好微软也好这些技术巨头们的核心能力都是拥有自己的语言和生态。可见编译技术有多么重要
## 编译技术,与你的工作息息相关
但也有一些程序员认为:“我不可能自己去写一门新的语言,还有必要学习编译原理吗?”
这种想法是把编译原理的用途简单化了。**编译原理不是只能用于炫耀的屠龙技。** 别的不说,作为程序员,**在实际工作中你经常会碰到需要编译技术的场景。**
Java程序员想必很熟悉Hibernate和Spring前者用到了编译技术做HQL的解析后者对注解的支持和字节码动态生成也属于编译技术。所以如果你要深入理解和用好这类工具甚至想写这种类型的工具会需要编译技术。
而PHP程序员在写程序的时候一般会用到模板引擎实现界面设计与代码的分离。模板引擎对模板进行编译形成可执行的PHP代码。模板引擎可以很强大支持条件分支、循环等语法。如果你了解编译技术会更容易掌握这些模板引擎甚至写出更符合领域需求的模板引擎。
我们2001年开发了一款工作流软件里面有依据自定义公式判断流转方向的功能。像这类需要用户自定义功能的软件比如报表软件、工资管理软件等都需要编译技术。
如果你要参与编写一个基础设施类的软件比如数据库软件、ETL软件、大数据平台等很多需要采用编译技术提供软件自带的语言功能比如SQL。这种功能无法由外部通用语言实现。
除此之外解析用户输入防止代码注入为前端工程师提供像React那样的DSL像TypeScript那样把一门语言翻译成另一门语言像CMake和Maven那样通过配置文件来灵活工作以及运维工程师分析日志文件等等高级别的需求都要用到编译技术。
**除了丰富的应用场景,学习编译技术对于提升程序员的竞争力也很重要。**现在一些大公司在招聘程序员时,有难度的面试题都是涉及底层机制的。因为理解了底层机制,才能有更深入思考问题,以及深层次解决问题的能力,而不是只能盲目地搜索答案,从表面解决问题。而学习编译原理能让你从前端的语法维度、代码优化的维度、与硬件结合的维度几个方面,加深对计算机技术的理解,提升自己的竞争力。
所以,无论你是前端工程师、后端工程师,还是运维工程师,不论你是初级工程师还是职场老手,编译技术都能给你帮助,甚至让你提升一个级别。
## 编译技术并不难学
但问题来了,你可能会说:“我知道编译技术很重要,我也很想把它啃下,可是我每次鼓起勇气拿起《编译原理》,啃不了多少页就放下了。编译原理已经成了我的心魔……”
在我看来,你之所以遇到困难,很大一个原因在于市面上讲述编译原理的内容往往过于抽象和理论化。学习,说到底是一个学和练,以及学以致用的过程。所以在和朋友们沟通了解之后,我想用下面的思路组织课程内容,帮你克服畏难情绪,更好地理解和学习编译原理。
**我会通过具体的案例带你理解抽象的原理。**比如语义分析阶段有个I属性和S属性传统课本里只专注I属性和S属性的特点和计算过程很抽象。那么我会分析常用语言做语义分析时哪些属性是I属性哪些是S属性以及如何进一步运用这些属性来让你更直观地了解它们。
**我也会重视过程,带你一步步趟过雷区。**我写了示例程序,带你逐渐迭代出一门脚本语言和一门编译型语言。当然了,我们会遇到一些挑战和问题,而在解决问题的过程中,你会切切实实体会到某个技术在哪个环节会发挥什么作用。最重要的是,你会因此逐渐战胜畏难情绪,不再担心看不懂、学不会。
**我还会让你在工作中真正运用到编译技术。**课程里的代码可以给你的工作提供参考。我介绍的Antlr和LLVM工具前者能帮你做编译器前端的工作后者能帮你完成编译器后端的工作。在课程中你能真正运用编译技术解决报表设计等实际问题。
为了帮你迅速了解课程的知识结构体系,我画了一张思维导图。**课程从三方面展开,包括实现一门脚本语言、实现一门编译型语言和面向未来的编程语言。**
![](https://static001.geekbang.org/resource/image/b1/ef/b12b9372917d3ce582a20fcf5e25c0ef.jpg)
* 课程的第一部分主要聚焦编译器前端技术,也就是通常说的词法分析、语法分析和语义分析。我会带你了解它们的原理,**实现一门脚本语言。**我也会教你用工具提升编译工作的效率,还会在几个应用场景中检验我们的学习成果。
* 第二部分主要聚焦编译器后端技术也就是如何生成目标代码和对代码进行优化的过程。我会带你纯手工生成汇编代码然后引入中间代码和后端工具LLVM**最后生成可执行的文件能支持即时编译,并经过了多层优化。**
* 第三部分是对编译技术发展趋势的一些分析。**这些分析会帮助你更好地把握未来技术发展的脉搏。**比如人工智能与编译技术结合是否会出现人工智能编程?云计算与编译技术结合是否会催生云编程的新模式?等等。
## 写在后面
课程虽然只有30多节但每节课绝对是干货满满。我希望这个课程能让所有有志于提升自己技术的工程师顺利攻下编译技术这重要的一关能够在工作中应用它见到实效并且对编程理解更上一层。
最后我希望你在留言区立下Flag写下自己的计划在“极客时间”与志同道合的朋友互相监督一起学习一起进步
![](https://static001.geekbang.org/resource/image/00/66/008ff7b6092be5463a414a0e0771dc66.jpg)