编译原理(一)自展法、编译器自举

本文介绍了编译原理中的自展法和编译器自举概念。自展法通过将语言拆分成多层,逐步构建编译器,简化了直接用机器语言编写编译器的复杂性。编译器自举则是用编译器自身语言编写编译器,使语言成为自编译语言。文章以Pascal编译器为例,阐述了自举过程,并探讨了为何编译语言的反编译难度较大,主要源于编译后的中间代码优化导致源代码难以还原。
摘要由CSDN通过智能技术生成

前言

新兴语言井喷,实际上都是踩在前辈肩膀上进行功能特化的结果,本系列从编译的角度找到语言的共性和不同语言的联系。

编译器是将源语言(通常指高级语言)转换成目标语言的程序,这个程序也是由某种语言写成并运行的。通常我们希望一个语言的编译器能够运行在裸机上而不依赖其他编译器才能运行,即机器语言。但直接用机器语言实现编译器实在太过麻烦,可以通过自展法一步步简化编写。

一个由语言L编写的,将语言X程序文件翻译成语言Y程序文件的翻译程序称为编译器,记作

自展法

直接用语言A(assembly)完成的全部内容可能比较复杂。现在考虑到一个特点:

一个语言L本身是可分割的,内部可以再抽出多层作为单独的语言,比如L1,L2,L3……,L1是整个L的核心,可以编写出等价的L2实现的功能,L1(和L2)可以编写出L3实现的功能,如此递归地包裹多层最后构成整个L。

实现前,可以单独先实现,然后

  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值