2.3.2 语法分析树与二义性 上下文无关文法及其语法树,用上下文无关文法描述程序语言 句型和语法树 一个句型对应的不同推导序列 文法二义性 有关文法的实用限制 (文法化简),1.用上下文无关文法描述程序语言,Ei | E+E | E*E | (E)| i:=Eif then | if elseva
抽象语法树Tag内容描述:
1、2.3.2 语法分析树与二义性 上下文无关文法及其语法树,用上下文无关文法描述程序语言 句型和语法树 一个句型对应的不同推导序列 文法二义性 有关文法的实用限制 (文法化简),1.用上下文无关文法描述程序语言,Ei | E+E | E*E | (E)| i:=Eif then | if elsevar :integeri | , i,补充例,2. 句型和语法树 (推导树),复习: 句型、句子、推导,E,(,E,),E,+,E,E,*,E,i,i,i,p31,E (E) (E+E) (E*E+E) (i*E+E) (i*i+E) (i*i+i),语法树 (推导树),开始符号,句型的推导,文法G: EE+E| E*E| (E)| E 句型 (i*i+i),句型,补充例,GS: SaAS ASbA ASS Sa 。
2、,动词,系动词,实义动词,be动词,表变化的,表感官的,主谓,主谓宾,主谓宾宾补,主谓宾,主谓宾宾,不定式宾语,动名词宾语,不定式动名词都行,不定式省to宾补,不定式宾补,省不省to 都行,现在分词宾补,16,6,5,4,3,2,1,15,14,13,12,11,10,9,8,7,句子,从句 3点,There be结构,时态 3点,非谓语动词 形式3变,17,1 动词 : 无论是哪种语言, 动词都是句子的灵魂, 把它叫谓语, 执行动作的就是主语, 承受动作的就是宾语, 这就是句子的基本构架. 如: I play basketball in the afternoon.主语 谓语 宾语 (记住划句子成分的符号)动词做谓语一定要清楚它是什么时。
3、中学英语语法体系知识树,总 述,名词分类,名词的数,量,格,人称代词,反身代词,物主代词,疑问代词,指示代词,不定代词,数词的分类,形 容 词,副词,等级,比较级的几个 特别用法,动词,助动词,常见助动词的用法,时态的标志词及构成,16种时态 的构成,一般现在时,现在 进行时,一般将来时,现在完成,被动语态,不同时态的 被动语态,句子,反意疑问句,规则,规则,非谓语动词,定语从句中 的关系代词,分词,不定式,不定式,v to do sth,做主语,作补语,。
4、3.5 上下文无关文法及其语法树,上下文无关文法及其语法树 二义性,1. 上下文无关文法及其语法树,语法树是推导序列的几何描述 例 文法G: EE+E| E*E| (E)| i 证明 (i*i+i) 是文法G的句型练习GS: SaAS | a ASbA | SS | ba构造句型aabbaa的语法树,语法树和推导序列,一棵语法树的不同构造过程对应了不同的推导序列 如果我们坚持用最左(最右)推导, 那么一棵语法树就完全等价于一个最左(最右)推导.,定理:句型和语法树,G为上下文无关文法, 对于,有S , 当且仅当 G有以为结果的一棵语法树。,问题: 如何证明一个符号串是句型?如何证明一个符号串是句。
5、第二章 抽象语法表示,抽象语法表示ASN.1 Abstract Syntax Notation(ASN.1)是一种形式语言 提供统一的网络数据表示,用于定义应用数据的抽象语法和应用协议数据单元的结构。 OSI或SNMP管理信息库,都是用ASN.1定义的。 基本编码规则BER Basic Encoding Rule(BER)是一种编码规则 用ASN.1定义的应用数据在传送过程中按照BER变换成比特串。,本章内容,数据的表示,数据具有语法和语义两个方面 语法:指数据的表示形式,或者说构成数据的规则。 语义:指数据的内容及其含义。 同样的语义有不同的语法表示,数据的表示,确定要表示信息的数据类型。
6、第 5 讲,编译原理,西北农林科技大学本科教程,主讲教师:赵建邦,第三章 语法分析,3.1 文法和语言 3.2 推导与语法树 3.3 自顶向下的语法分析 3.4 自底向上的语法分析 3.5 规范规约的自底向上语法分析方法,第三章语法分析 3.2 推导与语法树 推导与短语 语法树与二义性重点掌握 短语、句柄的概念 二义性的消除,本讲目标,3.2.1 推导与短语 1、规范推导 在3.1.1节中,所给句子i+i*i推导序列中的每一步推导都是对句型中的最右非终结符用相应产生式的右部进行替换,这样的推导称为最右推导(规范推导),规范推导的逆过程称为规范规约 如果每一步。
7、,名词 Noun (n.),冠词 Article (art.),词类(十种),表示人或事物的名称。,用来连接词与词、短语与短语或句与句。,oh, hello, hi,a (an), the,and, or, but,表示说话时的喜悦、惊讶等感情。,in, on, of, to, under,用来代替名词、形容词或数词。,表示名词、代词等和句中其它词的关系。,用在名词前帮助说明名词所指的人或事物。,boy, pencil, book, backpack,代词 Pronoun (pron.),数词 Numeral (num.),表示数量或顺序,副词 Adverb (adv.),not, too, here, often,修饰动词、形容词或其它副词,连词 Conjunction (conj.),感叹词 Interjection。
8、第二章 抽象语法表示ASN.1,主要内容:,2.1 网络数据表示 2.2 ASN.1的基本概念 2.3 基本编码规则 2.4 ASN.1宏定义,数据的表示,数据具有语法和语义两个方面 语法:指数据的表示形式,或者说构成数据的规则。语义:指数据的内容及其含义。同样的语义有不同的语法表示,数据的表示,确定要表示信息的数据类型。对于不同类型的数据定义不同的操作。任何类型的数据最终都将被表示成为比特序列。,不同计算机系统的数据表示,网络中不同类型的计算机交互通信时,采用的 “语法”不同,这种差异决定了同一数据对象在不同计算机中被表示为不同的比特序。
9、clite语法类型的非概要信息和意义 (2014025704-116),Program:Declarations 和一个Compound; Declaration:个体Declaration序列; Declaration:个体变量,其类型和大小; Type:int,bool,float,char集合的部分; Statement:子类Compound,Skip,Assignment,Conditional和Loop; Compound:个体Statement序列,以他们出现的顺序执行。每一个出现在抽象语法树的相同层次。Skip:跳转语句 Assignment:将表达式赋给变量的语句,conditional:一个表达式(test)和两个语句(thenbranch和elsebranch),其中一个被执行则另一个则跳过。在if-then语句,elsebra。
10、 抽象语法树姓名:刘乐学号:2101470日期:2011/10/16抽象语法树(AST)1. AST 的基本概念在计算机科学中,抽象语法树(abstract syntax tree 或者缩写为 AST) ,或者语法树(syntax tree) ,是源代码的抽象语法结构的树状表现形式 1,这里特指编程语言的源代码。 树上的每个节点都表示源代码中的一种结构,图一是一段源代码的语法书结构,代码见附录一。所以说语法是“抽象”的,是因为这里的语法并不会表示出真实语法中出现的每个细节。比如,嵌套括号被隐含在树 的结构中,并没有以节点的形式呈现;而类似于 if-condition-then 这样的。
11、1第三章 抽象语法树在现代编译器的构造过程中,前端主要实现从源程序到中间形式(Intermediate Representation)的转换,而编译器的后端用来完成从中间形式到具体目标机代码的转换,这是一种广泛采用的编译器构造模型。虽然源程序到目标程序的直接转换是可行的,但是使用独立于具体目标平台的中间形式有以下优点:(1)使用中间形式可以比较容易地构造面向不同目标平台和不同语言的编译器。在不改动已有编译器前端的情况下,为新的目标平台构造一个生成该平台目标程序的后端,就可以构造出新平台的编译器。同样对于一个新的语言,在不改动。
12、抽象语法树,语法分析树,S,句子: 1 + (2 + (3 + 4) + 5 文法: S E | S + EE (S) | Number,语法分析树,S,为了表达这个表达式,是否真的需要如此复杂的树结构?,抽象语法树 (ASTs),+,+,5,1,+,2,+,3,4,S,S,+,E,5,S + E,1,( S ),S + E,E,4,S + E,2,E,( S ),3,E,为了表达这个表达式,是否真的需要如此复杂的树结构?NO! 只需要使用 Abstract Syntax Trees 来替代.,如何来构建AST?,构建抽象语法树的最佳途径是伴随句子的语法分析过程;为每个“重要的”产生式规则构建内部的树结点,使用指针指向其叶子结点规则。需要能够掠过那些不重要的规则。