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_list à

initializer

| initializer_list ',' initializer

<初始化列表> -> <初始化>| <初始化列表 ',' 初始化器>

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

<选择语句> :IF< '(' 表达式 ')' 语句> | IF <'(' 表达式 ')' 语句 ELSE 语句 >

iteration_statementà

WHILE '(' expression ')' statement

| FOR '(' expression_statement expression_statement ')' statement

| FOR '(' expression_statement expression_statement expression ')' statement

<迭代语句> -> WHILE< '(' 表达式  ')' 语句 >| FOR '(' 表达语句 表达语句 ')' 语句 | FOR '(' 表达语句 表达语句 表达式 ')' 语句

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

: '&'

| '*'

| '+'

| '-'

| '~'

| '!'

assignment_operator à

'='

| MUL_ASSIGN

| DIV_ASSIGN

| MOD_ASSIGN

| ADD_ASSIGN

| SUB_ASSIGN

| LEFT_ASSIGN

| RIGHT_ASSIGN

| AND_ASSIGN

| XOR_ASSIGN

| OR_ASSIGN

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

direct_abstract_declarator à

'(' abstract_declarator ')'

| '[' ']'

| '[' constant_expression ']'

| direct_abstract_declarator '[' ']'

| direct_abstract_declarator '[' constant_expression ']'

| '(' ')'

| '(' parameter_type_list ')'

| direct_abstract_declarator '(' ')'

| direct_abstract_declarator '(' parameter_type_list ')'

labeled_statement à

IDENTIFIER ':' statement

| CASE constant_expression ':' statement

| DEFAULT ':' statement

1029 C语言文法的更多相关文章

  1. 1029 C语言文法定义与C程序的推导过程

    1 阅读并理解提供给大家的C语言文法文件. 2 参考该文件写出一个自己好理解版的现实版的完整版的C语言文法. 3 给出一段C程序,写出用上述文法产生这段C程序的推导过程. program → exte ...

  2. 1029 C语言文法翻译(2)

    program à external_declaration | program external_declaration 翻译:<源程序>→ <外部声明> | <源程序 ...

  3. 1029 C语言文法定义

    program à external_declaration | program external_declaration <源程序> ->  <外部声明> |  < ...

  4. C语言文法

    C语言文法 源程序 → 外部声明 | 子程序(外部声明) 外部声明   → 函数定义| 函数声明 函数定义 → 类型标识符(复合句) 标识符类型 → 无类型 | 字符型 | 整型 | 浮点型 整型→ ...

  5. 1014 C语言文法定义与C程序的推导过程 程序:冒泡算法C程序(语法树)

    阅读并理解提供给大家的C语言文法文件. 参考该文件写出一个自己好理解版的现实版的完整版的C语言文法. 给出一段C程序,画出用上述文法产生这段C程序的完整语法树. 程序:冒泡算法C程序 点此文字查看原图 ...

  6. 1029对c语言文法的理解

    <程序>→<外部声明>|<程序><外部声明> <外部声明>→<函数定义>|<声明> <函数定义>→< ...

  7. 我的mini_c语言文法设计

    //这个文件主要是用来描述当前源语言的词法结构和语法结构 //当前语言是c语言的一个子集,因此里面所有的描述大家都很熟悉 //注意,当前语言并不支持预处理,因为c预处理比较复杂,而且楼主能力低下,因此 ...

  8. 消除左递归c语言文法

    <程序> -〉 <外部声明> | <函数定义><外部声明> -〉<头文件> | <变量> | <结构体> <头 ...

  9. 简单的C语言文法

    <程序>→<外部声明>|<程序><外部声明> <外部声明>→<函数定义>|<声明> <函数定义>→< ...

随机推荐

  1. android source compiler

  2. Python基本数据类型之int 、 float

    首先要明确的是:在python中,一切皆为对象. 从底层角度看,对象就是保存在内存中的一个数据块.从抽象层看,对象就是我们的代码模拟出的一个类的独立个体. 在python中变量不需要声明类型,也不需要 ...

  3. 【Android测试】【随笔】获得App的包名和启动页Activity

    ◆版权声明:本文出自胖喵~的博客,转载必须注明出处. 转载请注明出处:http://www.cnblogs.com/by-dream/p/5157308.html 前言 经常看到一些刚刚接触Andro ...

  4. Shiro源码分析-初始化-Realm

    在上一篇介绍SecurityManager的初始化过程中,也有realm的粗略介绍. realm的概念在安全领域随处可见: 各种中间件的realm.spring security的realm.shir ...

  5. Round and Round We Go

    http://acm.hdu.edu.cn/showproblem.php?pid=1313 考查大整数与小整数相乘 #include<iostream> #include<cstd ...

  6. js保留n位小数

    1.功能:将浮点数四舍五入,取小数点后2位 function toDecimal(num) { var f = parseFloat(num); if (isNaN(f)) { return; } f ...

  7. Web设计者和开发者必备的28个Chrome插件

    摘要 对于许多Web设计者和开发者来说,Firefox浏览器是无法超越的,对于其他人Chrome正在蚕食Firefox的浏览器市场. 在过去的两年,谷歌Chrome浏览器的发布以来,引起了人们激烈争论 ...

  8. 利用css做扇形

    html和css每一块的边边角角都是直来直去,除了border-raius,要怎么做扇形了?当然,你如果只想要得到直角扇形,和半圆,那就很简单?那么做小于180的直角扇形,如何做了(大于180的直角无 ...

  9. saltstack之(七)配置管理系统初始化init

    saltstack的配置管理分环境管理:①.base为基础环境,一般会存放一些所有服务器都使用的配置管理信息.②.dev为开发测试环境,一般会存放一些开发测试服务器使用的配置管理信息.③.pro为线上 ...

  10. ava获得当前文件路径

    第一种: File f = new File(this.getClass().getResource("/").getPath()); System.out.println(f); ...