编译器学习之 (五) : 语义分析

前言

生成抽象语法树之后,下一步要做的就是对其进行分析,这个过程就称为语义分析,在此步骤我们需要做的有

  1. 变量引用的消解
  2. 类型名称的消解
  3. 类型定义检查
  4. 表达式的有效性检查
  5. 静态类型检查

以上的五个过程的执行顺序有着一定的限制.就是类型名称的消解类型定义检查的前提,而表达式的有效性检查在前三个过程结束前是不能执行的,介于它们执行顺序的关系,可以由下图表示

语义分析处理顺序

变量引用的消解

变量引用的消解是指将所有变量和它们的定义关联起来,例如变量a可能是全局变量a,也可能是静态变量a,还可能是局部变量a,为了消除这种不确定性,我们对它们进行和定义的关联.
具体操作就是给变量节点对象增加变量定义的属性.

类型名称的消解

在有的语言中,类型名称TypeRef类型实体Type是分开处理的,原因是TypeRef可以理解为类型的声明,Type则是类型的实现,我们有可能在实现之前就使用了这种类型.所以才会区分处理.
这里的消解,是将TypeRefType进行关联.通过一个TypeTable的对象去管理它们的对应关系.

类型定义的检查

类型定义的检查是检查在定义类型时使用了不符合逻辑的定义声明,比如

  1. 包含 void 的数组、结构体、联合体
  2. 成员重复的结构、联合体
  3. 循环定义的结构体、联合体

1和2的实现非常简单,这里就不赘述了,3可以这样来理解,结构体或者联合体对其他类型是引用可以看做是一个有向使用,相互之前的关系可以做成一个图

无闭环
有闭环

如果存在闭环,则存在循环定义.

检测有向图中的闭环的算法

要检测有向图是否存在闭环,可以使用如下算法.

  1. 选择任意一个节点并标注为查找中
  2. 沿着边依次访问所有与该节点相邻的节点
  3. 如果访问到的节点没有标注任何状态,则将节点标注为查找中;如果标注了``查找结束,则不做任何处理,返回之前的节点;如果标注为查找中`,则说明存在闭环.
  4. 从当前的节点重复步骤2和3,如果已经没有可访问的相邻节点,则将该节点标注为查找结束,并沿原路返回.
  5. 按照上述流程对所有节点进行处理,如果没有遇到查找中状态的节点,就说明不存在闭环.

表达式有效性检测

表达式需要检测的问题有

为无法赋值的表达式赋值(例:1 = 2 + 2)
使用非法的函数名调用函数(例:"string"("%d\n", i))
操作数非法的数组引用(例:1[0])
操作数非法的成员引用(例:1.memb)
操作数非法的指针间接引用(例:1->memb)
对非指针的对象取值(例:*1)
对非左值的表达式取地址

静态类型检查

语言的操作都对操作数的类型有所限制.例如结构体之间无法用 + 进行 加法运算,指针和数值之间无法用 * 进行乘法运算,将数组传递给参数类型为 int 型的函数会出现莫名其妙的结果.

对允许的操作数类型进行限制,例如 * 操作只适用于类型相同的数值之间,在编译过程中检查是否符合这样的限制的处理就是静态类型检查(static type checking).

静态类型检测的隐式类型转换

二元运算 * 只允许在相同类型的整数之间进行,但是如果在不同类型的数值之间进 行 * 运算,为了能够正常运算,编译器会自动对操作数的类型进行转换.这样的转换就称为隐式类型转换(implicit conversion).
例如,当int类型的值和long类型的值进行乘法运算时, 编译器会将两个操作数统一为 long 类型.

另外,在一些不得不强行转换为特定类型的情况下也会发生隐式类型转换.
例如,当 return 返回值的类型和函数返回值的类型不一致时,必须转换为函数返回值的类型
赋值运算时必须转换为和左值一致的类型等。显式声明的函数返回值或变量类型无法轻易改变,因此 只能利用隐式转换来改变值的类型。
在静态类型检查过程中也会实施隐式类型转换

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,602评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,442评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,878评论 0 344
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,306评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,330评论 5 373
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,071评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,382评论 3 400
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,006评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,512评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,965评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,094评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,732评论 4 323
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,283评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,286评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,512评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,536评论 2 354
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,828评论 2 345

推荐阅读更多精彩内容