编译器前端及工作原理

编译器前端(frontend)

  前端主要负责解析(parse)输入的源代码,由语法分析器和语意分析器协同工作。语法分析器负责把源代码中的‘单词’(Token)找出来,语意分析器把这些分散的单词按预先定义好的语法组装成有意义的表达式,语句 ,函数等等。 例如“a = b + c;”前端语法分析器看到的是“a, =, b , +, c;”,语意分析器按定义的语法,先把他们组装成表达式“b + c”,再组装成“a = b + c”的语句。
编译器后端(backend)

  编译器后端主要负责分析,优化中间代码(Intermediate representation)以及生成机器代码(Code Generation)。

工作方法
  首先编译器进行语法分析,也就是要把那些字符串分离出来。

  然后进行语义分析,就是把各个由语法分析分析出的语法单元的意义搞清楚。

  最后生成的是目标文件,也称为obj文件。

  再经过链接器的链接就可以生成最后的可执行代码了。

  有些时候需要把多个文件产生的目标文件进行链接,产生最后的代码。这一过程称为交叉链接。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值