20-第五章语义分析讲解.ppt

  1. 1、本文档共32页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
20-第五章语义分析讲解

第五章 语义分析 任课教师 王养廷 主要内容 语句体语义分析 程序实例分析 1 声明语义分析 Pascal程序 程序头 声明部分 语句部分 声明部分 语句体部分 1 声明语义分析(续) Pascal程序文法定义(声明部分) Program→program id(input, output);Block. Block →DecPart Body DecPart →LabelDecPart ConsDecPart TypeDecPart VarDecPart RoutDecPart Body → begin StatementList end ConstDecPart → const id=C;...; id=C;|λ TypeDecPart → type id=T;...; id=T;|λ VarDecPart → var VarList:T;...; VarList:T;c|λ RoutDecPart → RoutDec;...; RoutDec|λ RoutDec → ProcHead;Block|FuncHead;Block ProcHead → procedure id(ParamDecList) FuncHead → function id(ParamDecList):Type ParamDecList→ ParamDec;...;ParamDec ParamDec →VarList:Type| var VarList:Type| ProcHead| FuncHead 2 执行体的语义分析 Body文法 Body → BEGIN StatementList END StatementList → Statement [; StatementList] Statement → Var := Expr Statement → Var := id(ExprList) Statement → Var := IF Expr THEN Statement [ELSE Statement] FI Statement → Var :=While Expr DO Statement OD Statement → Var := FOR id := Expr TO Expr DO Statement OD 2 执行体的语义分析 执行体语义分析任务 静态语义检查 进行语义转换 具体任务 标识符是否有定义,重复定义 运算分量类型是否相容 说明 在后面几章还将介绍部分语义分析内容 2 执行体的语义分析 program pl0(input,output); const norw = 11; {no. of reserved words} type symset = set of symbol; var ch: char; {last character read} procedure error(n: integer); begin writeln( ****, : cc-1, ^,n: 2); err := err+1 end {error}; begin {main program} for ch := chr(0) to chr(255) do ssym[ch] := nul; getsym; end. 2 执行体的语义分析 Body部分的定义 Body() begin next_token(); StatementList(); next_token(); end; StatementList() begin statement(); if token=“;” then next_token();StatementList() end; 2 执行体的语义分析(续) statement() begin case token of LABEL :LabelStatement(); ID : idStatement(); GOTO : gotoStatement(); IF : ifStatement(); WHILE : whileStatement(); FOR : forStatement(); end end 2 执行体的语义分析(续) 赋值语句 语法结构: Var := Expr 语句分析 起始词:标识符 与调用语句相同 如何处理??(语法,语义) 回来再看看前面的总控程序 ID : idStatement(); 2 执行体的语义分析(续

您可能关注的文档

文档评论(0)

000 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档