上下文无关文法(Content-Free Grammar, CFG)
2009-08-20 00:06
267 查看
在计算机科学中,一个形式文法 G = (VT, VN, S, P) 称之为上下文无关的,其中,VT为终结符的集合,VN为非终结符的集合,S为开始符号(必须在某个产生式的左边出现一次),P是产生式的集合,如果它的产生式规则都取如下的形式:V -> w ,这里 V∈VN ,w∈(VT∪VN)* 。开始符号是一种特殊的非终结符,而所谓终结符号是组成语言的基本符号,从语法分析的角度来看,中介符号是一个语言不能再进行分割的基本符号.上下文无关文法取名为“上下文无关”的原因就是因为字符 V 总可以被字串 w 自由替换,而无需考虑字符 V 出现的上下文。一个形式语言是上下文无关的,如果它是由上下文无关文法生成的﹙条目上下文无关语言﹚。
上下文无关文法重要的原因在于它们拥有足够强的表达力来表示大多数程序设计语言的语法;实际上,几乎所有程序设计语言都是通过上下文无关文法来定义的。另一方面,上下文无关文法又足够简单,使得我们可以构造有效的分析算法来检验一个给定字串是否是由某个上下文无关文法产生的。例子可以参见 LR 分析器和 LL 分析器。
BNF ﹙巴克斯-诺尔范式﹚经常用来表达上下文无关文法。
文法规则使用相似的表示法。名字用斜体表示(但它是一种不同的字体,所以可与正则表达式相区分)。竖线仍表示作为选择的元符号。并置也用作一种标准运算。但是这里没有重复的元符号(如正则表达式中的星号*),稍后还会再讲到它。表示法中的另一个差别是现在用箭头符号“→”代替了等号来表示名字的定义。这是由于现在的名字不能简单地由其定义取代,而需要更为复杂的定义过程来表示,这是由定义的递归本质决定的。
同正则表达式类似,文法规则是定义在一个字母表或符号集之上。在正则表达式中,这些符号通常就是字符,而在文法规则中,符号通常是表示字符串的记号。我们利用C中的枚举类型定义了在扫描程序中的记号;为了避免涉及到特定实现语言(例如C)中表示记号的细节,就使用了正则表达式本身来表示记号。此时的记号就是一个固定的符号,如同在保留字 while 中或诸如+或: =这样的特殊符号一样,对于作为表示多于一个串的标识符和数的记号来说,代码字体为斜体,这就同假设这个记号是正则表达式的名字(这是它经常的表示)一样。
转载地址:http://hi.baidu.com/spidermanzy/blog/item/85b3206dd2c30dfa431694fc.html
上下文无关文法重要的原因在于它们拥有足够强的表达力来表示大多数程序设计语言的语法;实际上,几乎所有程序设计语言都是通过上下文无关文法来定义的。另一方面,上下文无关文法又足够简单,使得我们可以构造有效的分析算法来检验一个给定字串是否是由某个上下文无关文法产生的。例子可以参见 LR 分析器和 LL 分析器。
BNF ﹙巴克斯-诺尔范式﹚经常用来表达上下文无关文法。
文法规则使用相似的表示法。名字用斜体表示(但它是一种不同的字体,所以可与正则表达式相区分)。竖线仍表示作为选择的元符号。并置也用作一种标准运算。但是这里没有重复的元符号(如正则表达式中的星号*),稍后还会再讲到它。表示法中的另一个差别是现在用箭头符号“→”代替了等号来表示名字的定义。这是由于现在的名字不能简单地由其定义取代,而需要更为复杂的定义过程来表示,这是由定义的递归本质决定的。
同正则表达式类似,文法规则是定义在一个字母表或符号集之上。在正则表达式中,这些符号通常就是字符,而在文法规则中,符号通常是表示字符串的记号。我们利用C中的枚举类型定义了在扫描程序中的记号;为了避免涉及到特定实现语言(例如C)中表示记号的细节,就使用了正则表达式本身来表示记号。此时的记号就是一个固定的符号,如同在保留字 while 中或诸如+或: =这样的特殊符号一样,对于作为表示多于一个串的标识符和数的记号来说,代码字体为斜体,这就同假设这个记号是正则表达式的名字(这是它经常的表示)一样。
转载地址:http://hi.baidu.com/spidermanzy/blog/item/85b3206dd2c30dfa431694fc.html
相关文章推荐
- 上下文无关文法(CFG)
- 到底什么是上下文无关文法(CFG)?
- 【CT】三、上下文无关文法,CFG,PDA
- 从上下文无关文法(CFG)到语法分析树——LL(1)分析法
- 从上下文无关文法(CFG)到语法分析树——SLR(1)分析法
- 自然语言 和编译原理中的(1型文法)上下文有关文法和(2型文法)上下文无关文法CFG
- 句法模式识别(二)-正规文法、上下文无关文法
- 上下文无关文法
- 语法分析(1)---上下文无关的文法(context-free grammars)
- 句法模式识别(二)-正规文法、上下文无关文法
- 【编译原理】(2)上下文无关文法
- 上下文无关文法、上下文有关文法
- 上下文无关文法
- 上下文无关文法解析
- 文法系列之从上下文无关语法到转换语法
- 上下文无关文法1
- 正则表达式和上下文无关文法
- 【现代编译器】语法分析——正则表达式,上下文无关文法,递归下降分析,分析树
- 正则表达式与上下文无关文法
- 文法系列之从上下文无关语法到转换语法