【编译原理】入门总结

教程资源

入门教程在:手把手教你做一个 C 语言编译器


学习过程

19年尝试学了一下,中途看不懂放弃了。20年底从头再看一遍,经过一年的知识积累,在仔细研读之下,终于算是学懂了。此文中记录了我在最初学习时遇到的问题,和最终的解决方法记录下来,希望对读者有所帮助。


虚拟机

虚拟机涉及的知识是比较综合性的,是一个难点。虚拟机的原理是,模拟实现CPU的指令集。CPU的指令功能无非就是操作存储和调用运算资源,我们完全可以自己模拟实现。这样我们就可以不生成直接运行在电脑上的机器码,不用关心exe文件格式,而是实现一个简单的虚拟机来把源码当做脚本来执行。如此,机器码生成的任务可以大大减少,降低入门难度。


BNF

刚开始学的时候遇到的问题是,弄不懂BNF。BNF只有弄懂了,才会自己写,才会用代码实现。个人对BNF的理解见我的另一篇博客:编译原理—理解BNF。


逻辑流程图

在脑海中要有一张如下图的逻辑流程图:
在这里插入图片描述
其中,符号表特别重要,源码中的重要信息都是保存在符号表中的。

要特别说一下,比较容易纠结的问题是,为什么按照上面的流程先解析Token,再语法分析,就可以解析代码了?知其然还要知其所以然。我的理解是,编程语言在设计的时候,就考虑到,一要能准确无误的表达出一个操作,没有歧义;二是为了能使编译器更易于实现。编程语言并不是一下子就设计好的,很可能是在设计编译器的过程中不断丰富完善的。举一个例子:为什么标识符不能以数字开头?因为,如果标识符以数字开头,编译过程中就需要更多的判断来分辨到底是一个标识符还是一个数字或者表达式,直接规定不允许以数字开头,保证了不同类型的Token起始符号不同,就可以很容易判断Token的类型了。


动手实践

在原教程的基础上,可以自己尝试实现具有更强功能的C语言脚本,如支持结构体解析,如在解析代码的基础上,实现编辑器上下文提示等等。

同时,在对编译原理上下文无关文法的理解的基础上,学习其他语言,应该更加容易。

同时,可以自己开发一些小工具用来对代码进行自定义处理。


更加深入

后续可以学习已有脚本语言的实现原理,甚至可以尝试自己开发一款脚本语言,学无止境,再接再厉!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/437184.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python数据可视化从入门到实战_《Python编程从入门到实践》json数据可视化练习详解...

《Python编程从入门到实践》16.2中,计算收盘价均值的程序有些不易看懂,结合我自己的理解进行一些说明。使用的数据集:join格式的数据,数据集是由多个字典为元素组成的列表。每个字典包含如下信息[{"date": "2017-0…

【转】C# WebAPI中为自定义模型设置JSonConverter

我的WebAPI应用程序中有一个模型,用.NET 4.0编写,含有一个System.Net.Mime.ContentType类型的属性,如下所示: [Serializable] public class FileData {private ContentType contentType;private long size;private string name;public ContentType ContentType{get …

Qt添加翻译文件

以在Qt Creator中开发为例: 第一步 在.pro文件中添加一行 TRANSLATIONS projectName_zh.ts 保存,执行一次qmake。 注:ts文件是xml文件保存了需要翻译的信息。 第二步 选择菜单:工具->外部->Qt预言家->更新翻译。 可…

python爬虫淘宝手机_【Python3 爬虫】14_爬取淘宝上的手机图片

现在我们想要使用爬虫爬取淘宝上的手机图片,那么该如何爬取呢?该做些什么准备工作呢?首先,我们需要分析网页,先看看网页有哪些规律我们可以看到左侧是主题市场,将鼠标移动到【女装/男装/内衣】这一栏目&…

【转】WebSocket初探

定义: 遵循RFC6544协议的通信协议。Webcoket协议和http协议属于并行关系,但是websocket是以http协议为基础开发出来的(微软用IhttpHandler接口中同时处理这两种协议),同时他们都是以TCP协议为基础。可以进行双向通信、…

应用程序标准输入输出、Shell、程序界面的关系

发展史 计算机在发展初期,电脑上的软件是没有窗口的,只有一个命令行,这个软件叫Shell,中文的意思是外壳。Shell是一个统一的叫法,实际在不同的系统中,又有很多种Shell软件,如下表所示&#xff…

安卓简单天气预报app源码_七个个小众但实用的APP,效率翻倍~

推荐7个小众但实用的APP1、PDF处理助手下面就是软件的启动图,没有任何广告。并且直接标明了这个软件的三大特点:简单、免费、快捷下面就是软件的启动图,没有任何广告。而且免注册登录即可使用,简直是一款良心软件了。2、菜鸟教程菜…

【转】Jenkins详细教程

最近花了一段时间研究jenkins这个工具。所以写下这篇文章,算是当做记录吧! 一、jenkins是什么? Jenkins是一个开源的、提供友好操作界面的持续集成(CI)工具,起源于Hudson(Hudson是商用的),主要…

【Github】怎么在README.md中添加图片?

原理是将图片作为文档上传,在README.md中引用即可。 参考博客:【GitHub】给GitHub上的ReadMe.md文件中添加图片怎么做 、 gitHub创建文件夹

拼接符 防注入正则校验_Apache Kylin 命令注入漏洞调试分析(CVE-2020-1956)

1、前言Apache Kylin是一个开源的、分布式的分析型数据仓库,提供Hadoop/Spark 之上的 SQL 查询接口及多维分析(OLAP)能力以支持超大规模数据。近日,百度云安全团队监测到Apache官方发出了一个漏洞通告,披露了Apache kylin多版本存在命令注入漏…

【转】一个ASP.NET MVC中ajax调用WebApi返回500 Internal Server Error的调错方法。

ASP.NET MVC 引入的WebApi自然且较好地满足了ajax的交互需求,但使用jQuery ajax调用WebApi返回500 Internal Server Error时却不太好查找错误。在一个实际项目中,WebApi方法全部使用了try-catch捕获异常,并返回定制的错误消息,想当…

【Github】开源项目xterm.js

项目github地址: xterm.js on github 学习笔记 从项目介绍中进行知识拓展 名称资料npmnpm 是干什么的?(非教程)semversemver:语义化版本规范在 Node.js 中的实现Hyper软件官网 >Theia官网 >Electron官网 >…

can使能上拉 gpio_IMX6ULL 的 GPIO 操作方法

来源:百问网作者:韦东山本文字数:1652,阅读时长:4分钟CCM: Clock Controller Module (时钟控制模块) IOMUXC : IOMUX Controller,IO 复用控制器 GPIO: General-purpose input/output,通用的输入…

【转】.NET 的 WebSocket 开发包比较

转载于http://www.oschina.net/translate/websocket-libraries-comparison-2 编者按 本文出现在第三方产品评论部分中。在这一部分的文章只提供给会员,不允许工具供应商用来以任何方式和形式来促销或宣传产品。请会员报告任何垃圾信息或广告。 Web项目常常需要将数…

【编译原理】为什么编程语言中,标识符不能以数字开头?

标识符不能以数字为开头, 是为了简化词法解析器设计和实现,规避词法解析中以数字开头的变量与数字解析冲突的问题。 如果两种类型的词,如果起始符号不同,那么可以很容易把二者区分开;如果起始符号相同,那么以下符号&a…

vb checkbox选中和不选中_UE4 4.23 RetainerBox 选中框位置不正确

Bug表现在UE4 4.23版本,实现自定义控件时,继承了RetainerBox,发现当内部包裹子控件时,先编辑器面板选中子物体,发现选中位置有偏移。位置偏移当窗口缩放时,选中框位置发现当窗口最小化时,偏移位…

python编辑器spyder运行_使用spyder编译器单步调试python

1、将需要进行单步调试的函数在脚本中进行调用(十分重要的一步)。由于python是解释型语言,在进行单步调试的时候需要告诉系统你使用了这个函数,单步调试才会进入你所需要调式的函数。如下图所示,我们定义了createDataSet()函数,在…

去哪查阅ISO国际标准?

ISO官网 访问ISO官网,不需要翻墙,只要懂点英文就行。 ISO官网地址:https://www.iso.org/(可进行全面了解、购买付费内容) ISO部分公开标准下载地址:https://standards.iso.org/ittf/PubliclyAvailableSt…

【转】开源的C# websocket-sharp组件解析

下面我们介绍一款WebSocket组件websocket-sharp的相关内容。 一.websocket-sharp组件概述 websocket-sharp是一个C#实现websocket协议客户端和服务端,websocket-sharp支持RFC 6455;WebSocket客户端和服务器;消息压缩扩展;安全连接…

【编译原理】什么是上下文无关文法?

上下文无关是指,一句话的含义与其前后的内容没有或者几乎没有关系,只由自己决定,把它剪切到其他任何位置,也还是原有的意思。 例如: ... a 0; ...这是一个赋值语句,无论此语句的前后是什么代码&#xff…