<program>-><external_declaration> | <program> <external_declaration>

<external_declaration> -><function_definition> | <declaration>

<function_definition> -><type_specifier> <declarator> <compound_statement>

<type_specifier>->void | char | int | float

<declarator>-><pointer direct_declarator> | <direct_declarator>

<Pointer>->'*'| '*' pointer

<direct_declarator>-><IDENTIFIER> |<direct_declarator’[‘ ‘]’>
|<direct_declarator ’[’ constant_expression ’]’>
| <identifier '(' parameter_list ')'>
| <IDENTIFIER '(' ')'>|<direct_declarator ‘,’ identifier_list>

<identifier_list>-><: IDENTIFIER>| <identifier_list ',' IDENTIFIER>

<constant_expression>-><conditional_expression>

<parameter_list>-><parameter_declaration>| <parameter_list> <','> <parameter_declaration>

<parameter_declaration>-><declaration_specifiers><IDENTIFIER>

<compound_statement>-><'{'< >'}'> | <'{'><statement_list><'}'>| <'{'><declaration_list statement_list ><'}'

<declaration_list>-><declaration>| <declaration_list><declaration>

<Declaration>-><init_declarator>| <init_declarator_list>< ','> <init_declarator>

<init_declarator>-><declarator>| <declarator> <'='> <initializer>

<Initializer >-><assignment_expression>| <'{'>< initializer_list>< '}>' |< '{'>< initializer_list>< ','> < '}'>

<initializer_program_list>-><initializer_program>| <initializer_program_list>< ','> <initializer_program>

<statement_list>-><statement>| <statement_list> <statement>

<Statement >->| <compound_statement> | <expression_statement> | <selection_statement> | <iteration_statement> | <jump_statement>

<expression_statement> -> < ';'> | <expression>< ';'>

<selection_statement> -> <:>< IF>< '('>< expression ><')'> <statement>
| <if> <'('>< expression ><')'> <statement><else> <statement>

<iteration_statement>-><while>< '('>< expression ><')'>< statement>
| <for> <'('>< expression_statement>< expression_statement>< ')'>< statement>
| <for> <'('>< expression_statement>< expression_statement>< expression ><')'>< statement>

<jump_statement>-> | CONTINUE< ';'> | BREAK< ';'> | RETURN <';'> | RETURN <expression> <';'>

<expression>-> <: ><assignment_expression> | <expression> <','> <assignment_expression>

<assignment_expression>-><conditional_expression>| <unary_expression>< assignment_operator>< assignment_expression>

<conditional_expression >-> <logical_or_expression>
| <logical_or_expression>< '?'>< expression ><':'>< conditional_expression>

<logical_or_expression >->< logical_and_expression> | <logical_or_expression> OR_OP <logical_and_expression>

<logical_and_expression> -> <:>< inclusive_or_expression> | <logical_and_expression> AND_OP <inclusive_or_expression>

<inclusive_or_expression>-> <exclusive_or_expression> | <inclusive_or_expression ><'> | <'> <exclusive_or_expression>

<exclusive_or_expression>-><:> <and_expression>| <exclusive_or_expression> <'><^'> <and_expression>

<and_expression>-> <:>< equality_expression> | <and_expression ><'><&><'>< equality_expression>

<equality_expression>-><:>< relational_expression> | <equality_expression >EQ_OP <relational_expression> | <equality_expression> NE_OP <relational_expression>

<relational_expression><:> <shift_expression> | <relational_expression> <'><<><'> <shift_expression>

| <relational_expression '>' shift_expression>| <relational_expression LE_OP shift_expression>| <relational_expression GE_OP shift_expression>

<shift_expression>-> <:>< additive_expression> | <shift_expression LEFT_OP additive_expression> | <shift_expression RIGHT_OP additive_expression>

<additive_expression>-><:> <multiplicative_expression> 
| <additive_expression> <'+'> <multiplicative_expression>
| <additive_expression> <'-'> <multiplicative_expression>

<multiplicative_expression> -> <:> <cast_expression>
| <multiplicative_expression> <'*'> <cast_expression>
| <multiplicative_expression> <'/'> <cast_expression>
| <multiplicative_expression> <'%'> <cast_expression>

<cast_expression>-><:>< unary_expression> | <'('>< type_name ><')'>< cast_expression>

<unary_expression> ->< :> <postfix_expression>
| <INC_OP unary_expression>
| <DEC_OP unary_expression>
| <unary_operator>< cast_expression>
| <SIZEOF unary_expression>
| <SIZEOF> '('>< type_name ><')'>

<postfix_expression >-><:> <primary_expression>
|< postfix_expression> <'['>< expression ><']'>
| <postfix_expression ><'('>< ')'>
| <postfix_expression '(' argument_expression_list ')'>
| <postfix_expression '.' IDENTIFIER>
| <postfix_expression PTR_OP IDENTIFIER>
| <postfix_expression INC_OP>
| <postfix_expression DEC_OP>

<primary_expression>->IDENTIFIER | CONSTANT | STRING_LITERAL | <'('>< expression ><')'>

<argument_expression_list>-> < :>< assignment_expression> | <argument_expression_list> <','> <assignment_expression>

<unary_operator>-> <:>< '&'> | <'*'> | <'+'> | <'-'>| <'~'> | <'!'>

<storage_class_specifier >-> TYPEDEF | EXTERN | STATIC | AUTO | REGISTER

<struct_or_union_specifier> ->< :>< struct_or_union IDENTIFIER>< '{'>< struct_declaration_list>< '}'>
| <struct_or_union ><'{' ><struct_declaration_list>< '}'>
| <struct_or_union> IDENTIFIER

<struct_or_union>-> <: >STRUCT | UNION

<struct_declaration_list> -> <:>< struct_declaration> | <struct_declaration_list ><struct_declaration>

<struct_declaration> -><:>< specifier_qualifier_list>< struct_declarator_list>< ';'>

<specifier_qualifier_list >-> < type_specifier>< specifier_qualifier_list>
| <type_specifier>
| <type_qualifier ><specifier_qualifier_list>
| <type_qualifier>

<struct_declarator_list>-><struct_declarator>
| <struct_declarator_list>< ','>< struct_declarator>

<struct_declarator>-> <:>< declarator> |< ':'>< constant_expression>
| <declarator ><':'> <constant_expression>

<enum_specifier >-> < ENUM '{' enumerator_list '}'>
| <ENUM IDENTIFIER '{' enumerator_list '}'>
| ENUM IDENTIFIER

<enumerator_list >-> enumerator | enumerator_list <','> enumerator

<Enumerator >->IDENTIFIER | IDENTIFIER <'='> <constant_expression>

<type_qualifier >->CONST | VOLATILE

<type_qualifier_list>-> <type_qualifier> | <type_qualifier_list> <type_qualifier>

<parameter_type_list>-> <parameter_list> | <parameter_list ><','> ELLIPSIS

<parameter_list>-> <:>< parameter_declaration> | <parameter_list>< ','>< parameter_declaration>

<type_name>->< specifier_qualifier_list> | <specifier_qualifier_list>< abstract_declarator>

<abstract_declarator>-> pointer | <direct_abstract_declarator> | <pointer direct_abstract_declarator>

ll1文法的更多相关文章

  1. 【编译原理】LL1文法语法分析器

    上篇文章[编译原理]语法分析--自上向下分析 分析了LL1语法,文章最后说给出栗子,现在补上去. 说明: 这个语法分析器是利用LL1分析方法实现的. 预测分析表和终结符以及非终结符都是针对一个特定文法 ...

  2. 表达式计算器(LL1文法)

    LL(1)文法求算数表达式的值递归子程序法 分析过程: 表达式文法G[E]:E->E+T|E-T|TT->T*F|T/F|T%F|FF->N^F|NN->(E)|NUM|+NU ...

  3. 编译原理LL1文法分析树(绘图过程)算法实现

    import hjzgg.analysistable.AnalysisTable; import hjzgg.first.First; import hjzgg.follow.Follow; impo ...

  4. 编译原理LL1文法分析表算法实现

    import hjzgg.first.First; import hjzgg.follow.Follow; import hjzgg.tablenode.TableNode; import hjzgg ...

  5. 编译原理LL1文法Follow集算法实现

    import hjzgg.first.First; import java.util.LinkedHashMap; import java.util.Map; import java.util.Set ...

  6. 编译原理 LL1文法First集算法实现

    import java.util.LinkedHashMap; import java.util.Map; import java.util.Set; import java.util.TreeMap ...

  7. Compiler Principles 语法分析

    语法分析的两种思维方式:1:自顶向下分析 :从语法树的根部推下来一直推到需要确认的终结符号串为止:就是为了找到一个符号串的最左推导 自顶向下分析,因为文法有些是以非终结符开头的另外文法中还可能含有右部 ...

  8. 软件工程学习之小学四则混合运算出题软件 Version 1.00 设计思路及感想

    对于小学四则混合运算出题软件的设计,通过分析设计要求,我觉得为了这个软件在今后便于功能上的扩充,可以利用上学期所学习的<编译原理>一课中的LL1语法分析及制导翻译的算法来实现.这样做的好处 ...

  9. 文法 LL1

    <程序>-><声明列表>|<程序><函数> <声明列表>-><声明>|<声明><声明列表> ...

随机推荐

  1. ajax对象。同步与异步及ajax发送请求

    ajax对象的属性.方法 属性 readyState: Ajax状态码 * 0:表示对象已建立,但未初始化,只是 new 成功获取了对象,但是未调用open方法 1:表示对象已初始化,但未发送,调用了 ...

  2. 领域驱动设计业务框架DMVP

    DMVP,全称DDD-MVP,是基于领域驱动设计(DDD)搭建的业务框架,整体设计符合DDD领域模型的规范,业务上达成了领域模型和代码的一一映射,技术上达成了高内聚低耦合的架构设计,开发人员不需要关注 ...

  3. acwing 3 完全背包

    习题地址 https://www.acwing.com/problem/content/description/3/ 题目描述有 N 种物品和一个容量是 V 的背包,每种物品都有无限件可用. 第 i ...

  4. sublime text 3 的emmet 添加自定义 html 片段

    比如想在html写 jquery 直接添加jquery地址,打开 ‘首选项->Package Setting->Emmet->Settings - User’, css也可以如法炮制 ...

  5. LDAP理论知识

    整理改编自: https://www.cnblogs.com/yjd_hycf_space/p/7994597.html http://blog.51cto.com/407711169/1439623 ...

  6. HTTP2 Sampler for JMeter

    今天开发大大说能不能帮忙压一下HTTP2的链接,便去查了一下相关的东西. HTTP 2.0 的出现,相比于 HTTP 1.x ,大幅度的提升了 web 性能.在与 HTTP/1.1 完全语义兼容的基础 ...

  7. ES6新特性使用小结(三)

    九.数据类型 Symbol /* * Symbol 数据类型 概念: Symbol 提供一个独一无二的值 * */ { let a1 = Symbol(); let a2 = Symbol(); co ...

  8. 长春理工大学第十四届程序设计竞赛(重现赛)H.Arithmetic Sequence

    题意: 数竞选手小r最喜欢做的题型是数列大题,并且每一道都能得到满分. 你可能不相信,但其实他发现了一个结论:只要是数列,无论是给了通项还是给了递推式,无论定义多复杂,都可以被搞成等差数列.这样,只要 ...

  9. 038 Count and Say 数数并说

    数数并说序列是一个整数序列,第二项起每一项的值为对前一项的计数,其前五项如下:1.     12.     113.     214.     12115.     1112211 被读作 " ...

  10. Zepto核心模块源代码分析

    一.Zepto核心模块架构 Zepto核心模块架构图 该图展示了Zepto核心模块架构代码的组织方式.主要分为私有变量.函数和暴露给用户的所有api. Zepto核心模块架构代码 该图展示了Zepto ...