上下文无关文法解析

简单例子:

Java语句: if ( expression )statements  else  statements

在文法中:使用变量expr 来表示 expression , 使用变量stmt来表示 statements

那个这个构造规则可以表示为:

                                 stmt → if( expr ) stmt else stmt

"→" 读作 "可以具有如下形式",以上规则叫做“产生式”。在产生式中 if、else、括号 这样的词法元素叫做 终结符号,

而 expr、stmt 表示终结符号的序列,叫做非终结符号。

文法定义:

一个上下文无关文法由4个元素组成:

  1. 一个终结符号集合,他们有时候也称为“词法单元”。终结符号是该文法所定义的语言的基本符号的集合。
  2. 一个非终结符号集合,他们有时候也称为“语法变量”。每个非终结符号表示一个终结符号串的集合。
  3. 一个产生式集合,每个产生式 都包含一个叫做产生式头或左部的非终结符号,一个箭头,和一个称为产生式体或右部的 由终结符号和非终结符号组成的序列。产生式主要用来表示某个构造的某种书写形式,如果产生式头表示某个构造,那么产生式体表示该构造的书写形式。
  4. 指定一个非终结符号为开始符号。

图示:

(未完待续.....)

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值