编译器之语义分析

来源:互联网 发布:跳跃网络充值积分 编辑:程序博客网 时间:2024/06/06 12:24

semantic: 语言的意义


编译器的语义分析阶段将变量与其用法关联起来,检查每个表达式是否有正确的类型,还有, 将抽象的语法翻译成更简单的形式以

方便生成机器语言(码)。


符号表

符号表将标识符和其类型、位置关联起来,当我们去处理变量,函数的声明时,就是将这些信息组织(绑定)起来,放在表里,当需
要知道这些函数,变量的意义时,就去这个表里查。

 每一个局部变量都有其作用域(scope). 举个例子, let D in E end
所有在D里面声明的变量、类型,还有函数只能在E结束之前是可见的,相应的,语义分析到达一个作用末尾时,后续的就直接丢弃处理。


我们将多个这种绑定叫做环境(environment), 用箭头 |-> 表示,比如, {g |->string, a|-> int|, 其函义为a是一个整型变量,g是一个字符串
型变量。

举一个简单的例子:

function f(a:int, b:int, c:int) =     (print_int(a+c); let var j := a+b     var a := "hello"   in print(a); print_int(j)  end;  print_int(b) )


1 0
原创粉丝点击