`
修博龙泉
  • 浏览: 317520 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

BNF巴科斯范式及其扩展

 
阅读更多
巴科斯范式及其扩展

BNF & Augmented BNF
什么是巴科斯范式
巴科斯范式(BNF: Backus-Naur Form 的缩写)是由 John Backus 和 Peter Naur 首次引入一种形式化符号来描述给定语言的语法(最早用于描述ALGOL 60 编程语言)。确切地说,早在UNESCO(联合国教科文组织)关于ALGOL 58的会议上提出的一篇报告中,Backus就引入了大部分BNF符号。虽然没有什么人读过这篇报告,但是在Peter Naur读这篇报告时,他发现Backus对ALGOL 58的解释方式和他的解释方式有一些不同之处,这使他感到很惊奇。首次设计ALGOL的所有参与者都开始发现了他的解释方式的一些弱点,所以他决定对于以后版本的ALGOL应该以一种类似的形式进行描述,以让所有参与者明白他们在对什么达成一致意见。他做了少量修改,使其几乎可以通用,在设计ALGOL 60的会议上他为ALGOL 60草拟了自己的BNF。看你如何看待是谁发明了BNF了,或者认为是Backus在1959年发明的,或者认为是Naur在1960年中发明。(关于那个时期编程语言历史的更多细节,参见1978年8月,《Communications of the ACM(美国计算机学会通讯)》,第21卷,第8期中介绍Backus获图灵奖的文章。这个注释是由来自Los Alamos Natl.实验室的William B. Clodius建议的)。
现在,几乎每一位新编程语言书籍的作者都使用巴科斯范式来定义编程语言的语法规则。
巴科斯范式的内容
在双引号中的字("word")代表着这些字符本身。而double_quote用来代表双引号。
在双引号外的字(有可能有下划线)代表着语法部分。
尖括号( < > )内包含的为必选项。
方括号( [ ] )内包含的为可选项。
大括号( { } )内包含的为可重复0至无数次的项。
竖线( | )表示在其左右两边任选一项,相当于"OR"的意思。
::= 是“被定义为”的意思。
巴科斯范式示例
这是用BNF来定义的Java语言中的For语句的实例:
FOR_STATEMENT ::=
"for" "(" ( variable_declaration |
( expression ";" ) | ";" )
[ expression ] ";"
[ expression ]
")" statement
这是Oracle packages的BNF定义:
package_body ::= "package" package_name "is"
package_obj_body
[ "begin" seq_of_statements ]
"end" [ package_name ] ";"
package_obj_body ::= variable_declaration
| subtype_declaration
| cursor_declaration
| cursor_body
| exception_declaration
| record_declaration
| plsql_table_declaration
| procedure_body
| function_body
procedure_body ::= "procedure" procedure_name
[ "(" argument { "," argument } ")" ]
"return" return_type
"is"
[ "declare" declare_spec ";" { declare_spec ";" } ]
"begin"
seq_of_statements
[ "exception" exception_handler ]
"end" [ procedure_name ] ";"
statement ::= comment
| assignment_statement
| exit_statement
| goto_statement
| if_statement
| loop_statement
| null_statement
| raise_statement
| return_statement
| sql_statement
| plsql_block
这是用BNF来定义的BNF本身的例子:
syntax ::=
rule ::= identifier "::=" expression
expression ::= term { "|" term }
term ::= factor
factor ::= identifier |
quoted_symbol |
"(" expression ")" |
"[" expression "]" |
"{" expression "}"
identifier ::= letter { letter | digit }
quoted_symbol ::= """ """
扩展的巴科斯范式 Augmented BNF
RFC2234 定义了扩展的巴科斯范式(ABNF)。近年来在Internet的定义中ABNF被广泛使用。ABNF做了更多的改进,比如说,在ABNF中,尖括号不再需要。
编辑本段
BNF(beat nation finial)

尖端的节奏一族,两种相辅相成的节奏模式
什么是BNF
BNF灵感来源于beat up and one two party,激乐社是劲舞团另类偏门的激舞模式与领舞模式的音乐制作爱好者团队,团队成员汇集中国大陆与港澳台资深玩家。
BNF介绍
BNF制作Beatup模式和One Two Party模式文件歌曲成型于2009年初,风行于2009年10月,第一个歌曲插件发表于2009年10月1日,以每15天更新一版的速度奉献给广大玩家。随着该团队技术的日臻成熟与更新歌曲的不断增加BNF作品已经得到国内外玩家的追捧。
〖自编激舞领舞〗由BNF全体成员构思创作超过70首自编的激舞领舞歌曲,其中一部分歌曲正处于修改完善中。
因有你的支持,我们才能更好的为大家带来更新更好的作品。
〖自编激舞〗曲目保留了国服,韩服,私服众多优秀的作品,再加上BNF自编工作室为大家带来了新的歌曲,集百家之长融会了最新的激舞歌曲,今后BNF将不断的更新激舞歌曲,创造属于国服的自编时代!
〖自编领舞〗一切还原AU里所有领舞新歌,绝不删除一首,还另添加3首自编领舞与韩服版本的4首歌曲。自编领舞作为最新的尝试,添加的歌曲并不难,除一首NO DANCE的高级歌曲外,其余2首都是现今流行的领舞歌曲节奏融会改编。BNF希望通过此次的尝试能让更多的领舞者门了解属于领舞的自编时代.
制作成果汇集了港澳台激舞精华人物的智慧结晶.
编辑本段
其他含义

英国国家处方集的缩写
分享到:
评论

相关推荐

    C、Java和Python的BNF范式

    BNF(巴科斯范式,Backus-Naur Form)是一种形式化语法的表示方法,广泛用于描述编程语言的语法结构。它由John Backus和Peter Naur在20世纪50年代末提出,旨在为ALGOL编程语言提供一个清晰的语法定义。在本资源中,...

    ISO_IEC_14977_1996(E) 信息技术 语法元语言 扩展的BNF标准(EBNF) .pdf

    信息技术 语法元语言 扩展的BNF标准(EBNF) 巴科斯范式(BNF: Backus-Naur Form 的缩写)是由 John Backus 和 Peter Naur 首先引入的用来描述计算机语言语法的符号集。现在,几乎每一位新编程语言书籍的作者都使用...

    RFC2234(SIP遵循的BNF范式)

    **ABNF(Augmented BNF for Syntax Specifications: ABNF)** 是一种基于传统巴科斯范式的扩展版本,用于描述语法规范。与原始的巴科斯范式相比,ABNF具有更丰富的表达能力和更加灵活的语法结构,能够更好地适应现代...

    用预测分析表实现c子集语法分析

    在创建预测分析表之前,我们需要将这些规则转化为BNF(巴科斯范式)或EBNF(扩展巴科斯范式)的形式,这是一种形式化的表示语言的语法结构的方法。 接着,我们需要构建预测分析表。预测分析表由状态和输入符号组成...

    SQL:SQL-92,SQL-99和SQL-2003的BNF语法

    BNF,巴科斯范式(Backus-Naur Form),是一种形式语法的表示方法,常用于描述编程语言或标记语言的语法结构。在SQL-92、SQL-99和SQL-2003中,BNF被用来精确地定义SQL的各种语句和表达式的结构,帮助开发者理解SQL的...

    sql-92-bnf.tar.gz_BNF SQL92_bnf_sql b_sql server bnf_sql92 bnf

    BNF(巴科斯范式)是一种形式语言的描述方法,全称为Backus-Naur Form,用于定义计算机语言的语法规则。在SQL-92 BNF中,我们可以通过这种形式化的描述理解SQL-92的语法结构。 "sql-92.bnf.html"这个文件很可能是对...

    熟悉编译原理BNF定义

    在学习编译原理时,了解并掌握巴科斯范式(Backus-Naur Form,简称BNF)定义是至关重要的基础。BNF是一种形式化的语法描述方法,用于定义上下文无关文法,它是编译器设计的基础工具之一。 实验二是对BNF定义的熟悉...

    b.rar_verilog ebnf

    EBNF是一种用于描述形式语言的符号表示法,它是原始巴科斯范式(BNF)的扩展,增加了更多的构造符来表达更复杂的文法规则。在EBNF中,可以表示重复、选择、可选等语法结构,使得文法规则的描述更加简洁和灵活。例如...

    编译原理课件(介绍了 文法和语法的一些定义,NFA,DFA文法,LL1。,LR1等等)

    通常,我们用BNF(巴科斯范式)或EBNF(扩展巴科斯范式)来定义文法。例如,"E -&gt; E + T | T" 表示一个表达式E可以由另一个表达式E加上一个项T构成,或者直接是一个项T。 接着,**NFA(非确定性有限状态自动机)**...

    北邮形式语言与自动机试题

    此外,考生可能需要理解和运用正则表达式、巴科斯范式(BNF)或扩展巴科斯范式(EBNF)来描述语言的结构。自动机的转换规则、接受状态、判定状态等问题也可能出现在这份试卷中。 第三份文档《形式语言与自动机试题....

    增加了case和for语句的pl0编译器及有关测试文件

    这份文档可能包含了BNF(巴科斯范式)或者EBNF(扩展巴科斯范式)形式的语法规则,帮助我们明确`case`和`for`语句的结构和使用方式。 `fix.txt`、`case.txt`和`for.txt`是测试文件,分别用于测试编译器对原生PL0...

    kgt:BNF争斗和铁路图

    BNF(巴科斯范式)是描述形式语言的一种方法,常用于定义编程语言的语法规则。在编译器设计中,BNF被用来构建解析器,帮助计算机理解程序员编写的源代码。 BNF(巴科斯范式,Backus-Naur Form)是一种形式语法的...

    BNF Parser²-开源

    BNF(巴科斯范式,Backus-Naur Form)是一种形式化语法的表示方法,广泛用于描述编程语言、数据格式和其他需要明确语法规则的系统。它由John Backus和Peter Naur在1960年代提出,是编译原理和解析技术中的基本概念。...

    形式语言自动机教学参考书.pdf

    同时,书中会介绍如何通过巴科斯范式(BNF)或扩展巴科斯范式(EBNF)来描述语言的语法结构。 自动机理论则是研究如何用一种计算设备,即自动机,来识别和处理这些形式语言。书中可能会详细讲解有限状态自动机的...

    yufa.rar_语法分析_语法分析实验

    另一个文件名为“简易语法”,很可能包含了实验所用到的具体语法定义,例如以BNF(巴科斯范式)或EBNF(扩展巴科斯范式)形式描述的语言规则。这些规则定义了输入的语句应该如何被解析和理解。用户可能需要根据这些...

    C++ 语法编译器 分析器

    "grammar.TXT"可能是C++的文法定义,通常以巴科斯范式(BNF)或扩展巴科斯范式(EBNF)的形式存在。文法定义了语言的规则,如语句、表达式、声明等,是编译器和分析器的基础。 "readme.txt"是常见的说明文件,通常...

    bnf-mode:GNU Emacs主要模式,用于编辑BNF语法

    BNF(Backus-Naur Form,巴科斯范式)是一种用于描述形式语言的语法规范,广泛应用于编译器设计、解析器构造和其他与计算机语言相关的领域。它通过一套规则来定义语言的结构,使得语言的语法规则可以清晰地表达出来...

    编译原理4个实验要求

    在此过程中,学生需要编写文法描述,如EBNF(扩展巴科斯范式)或BNF(巴科斯范式),并实现相应的解析算法。 3. 语义分析实验: 语义分析阶段检查程序的逻辑含义,确保其符合编程语言的语义规则。实验可能涉及类型...

    cache_server:缓存系统

    1 *数字内容= * OCTET 键值=长度SP长度SP内容内容响应=错误| 字节数组错\u8bef='-'字节数组注意: DIGIT是ABNF的基本规则,取值范围是0〜9 OCTET是ABNF的基本规则,取值范围是0x00〜0xFF扩展巴科斯范式(ABNF,增强...

Global site tag (gtag.js) - Google Analytics