c语言文法定义

<程序>→<外部声明>|<程序><外部声明>

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

<函数定义>→<类型说明><声明><复合语句>

<类型说明>→void|char|int |float

<声明>→<指针直接说明符>|<直接说明符>

<指针>→’*‘|‘*‘指针

<直接说明符>→<标识符>|<直接说明符‘[’‘]’>|<直接说明符‘[’常数表达式‘]’> |<标识符‘(’参数列表‘)’>|<标识符><‘(’‘)’>>|<直接说明符><‘,‘><标识符列表>

<标识符列表>→<:标识符>|<标识符列表><‘,‘><标识符>

<常数表达式>→<条件表达式>

<参数列表>→<参数声明>|<参数列表><‘,‘><参数声明>

<参数声明>→<声明说明符><标识符>

<复合语句>→<‘{’><‘}’>|<‘{‘><语句列表><‘}‘>|<‘{‘><声明列表><语句列表><‘}‘>

<声明列表>→<声明>|<声明列表><声明>

<声明>→<初始化声明>|<初始化声明列表><‘,’><初始化声明>

<初始化声明>→<声明>|<声明><‘=’><初始化程序>

<初始化程序>→<赋值表达式>|<‘{’><初始化程序列表><‘}’>|<‘{‘><初始化程序列表><‘,‘><‘}‘>

<初始化程序列表>→<初始化程序>|<初始化程序列表><‘,’><初始化程序>

<语句列表>→<语句>|<语句列表><语句>

<语句>→<复合语句>|<表达式语句>|<选择语句>|<循环语句>|<跳跃语句>

<表达式语句>→<‘;‘>|<表达式><‘;‘>

<选择语句>→<:><if><‘(‘><表达式><‘)‘><语句>|<if><‘(‘><表达式><‘)‘><语句><else><语句>

<循环语句>→<while><‘(‘><表达式><‘)‘><语句>|<for><‘(‘><表达式语句><表达式语句><‘)‘><语句>|<for><‘(‘><表达式语句><表达式语句><表达式><‘)‘><语句>

<跳跃语句>→ CONTINUE< ‘;‘>| BREAK <‘;‘>| RETURN <‘;‘>| RETURN <表达式> <‘;‘>

<表达式>→<:><赋值表达式>|<表达式><‘,‘><赋值表达式>

<赋值表达式>→<条件表达式>|<一元表达式><赋值操作符><赋值表达式>

<条件表达式>→<逻辑或表达> | <逻辑或表达><‘?‘> <表达式>< ‘:‘><条件表达式>

<逻辑或表达>→<逻辑与表达>  |< 逻辑或表达 或运算><逻辑表达式>

< 逻辑与表达>:<或表达式> |< 逻辑表达式 >和<运算或表达式>

< 或运算表达式>→<异或表达式> |< 或运算表达式 ><‘>|<‘>< 异或表达式>

< 异或表达式>:<与表达式> | < 异或表达式><‘^‘><与表达式>

< 与表达式>:<相等表达式> |< 与表达式><‘&‘><相等表达式>

< 相等表达式>:<关系表达式> |< 相等表达式等于运算关系表达式> | <相等表达式不等于运算关系表达式>

< 关系表达式>:<移位表达式> | <关系表达式><‘<‘><移位表达式 >|< 关系表达式><‘>‘><移位表达式>  |<  关系表达式小于等于运算移位表达式> |< 关系表达式大于等于运算移位表达式>

< 移位表达式>:<加法表达式> | <移位表达式左运算加法表达式>  |< 移位表达式右运算加法表达式>

< 加法表达式:<乘法表达式> |< 加法表达式><‘+‘><乘法表达式> |< 加法表达式><‘-‘><乘法表达式>

< 乘法表达式>:<强制转换表达式> | <乘法表达式><‘*‘><强制转换表达式> | <乘法表达式><‘/‘><强制转换表达式 >| <乘法表达式><‘%‘><强制转换表达式>

<  强制转换表达式>:<一元表达式>  |<  ‘(‘>< 类型名称 ><‘)‘><强制转换表达式>

<一元表达式>:<后缀表达式> | <INC运算一元表达式> |< DEC运算一元表达式> |< 一元运算符将表达式> | < 结构体变量的一元表达式 >| < 结构体变量的><‘(‘>< 类型名称>< ‘)‘>

<后缀表达式>:<基本表达式> | <后缀表达式><‘[‘><表达式><‘]‘>  |< 后缀表达式><‘(‘ ><‘)‘> | <后缀表达式>< ‘(‘><参数表达式列表><‘)‘ >  | <后缀表达式><‘.‘>< 标识符 >| <后缀表达式指针运算标识符>    |< 后缀表达式INC运算>  |< 后缀表达式DEC运算>

<基本表达式>→<标识符>  |<常量 >| <字符串常量> | < ‘(‘><表达式><‘)‘>

<参数表达式列表>:< 赋值表达式 >| <参数表达式列表><‘,‘><赋值表达式>

<一元运算符>:< ‘&‘>  | < ‘*‘>  | < ‘+‘>  | < ‘-‘>  | < ‘~‘>  |<  ‘!‘>

<赋值运算符>→<‘=‘>  |< 乘法分配> | <DIV分配> |< MOD分配> | <加法分配>  | < SUB分配>  |< 左分配 >| <右分配与分配>|< 异或分配 >|<或分配>

<存储类说明符>→<定义类型> |< 外部变量> |< 静态  >|< 自动>  | <寄存器>

<结构或联合说明符>:<结构或联合标识符><‘{‘><结构体声明列表><‘}‘>  |< 结构或联合><‘{‘><结构体声明列表><‘}‘ > |< 结构或联合标识符>

<结构或联合>:<结构体> |< 联合>

<结构体声明列表>:<结构体声明> |< 结构体列表声明结构体声明>

<结构体声明>:<说明符限定符列表结构说明符><‘;‘>

<说明符说明符限定符列表> →<类型说明符说明符限定符列表> |< 类型说明符>  |< 类型限定符说明符限定符列表 >| <类型限定符>

<结构说明符列表>→<结构体声明> |< 结构说明符列表><‘,‘><结构体声明>

<结构体声明>→<:><声明 >| < ‘:‘><常量表达式> |< 声明><‘:‘><常量表达式>

<枚举声明>→<枚举><‘{‘><枚举器列表><‘}‘>  | <枚举标识符><‘{‘><枚举器列表><‘}‘>  | <枚举标识符>

<枚举器列表>→<枚举器> | <枚举器列表><‘,‘>

<枚举器枚举器>→<标识符 >|< 标识符><‘=‘><常量表达式>

<类型限定符>→<常量 >|< 易失的>

<类型限定符列表>→<类型限定符> | <类型限定符列表><  类型限定符>

<参数类型列表>→<参数列表> | <参数列表><‘,‘><省略符号>

<参数列表>→<:><声明参数> |< 参数列表><‘,‘><声明参数>

<抽象说明符>→<指针> | <直接抽象说明符> | <指针直接抽象说明符>

<直接抽象说明符>→ <‘(‘> <抽象说明符 ><‘)‘ > |<  ‘[‘ ><‘]‘  >| < ‘[‘>< 常量表达式><‘]‘>| <直接抽象说明符><‘[‘>< ‘]‘>  | <直接抽象说明符><‘[‘>< 常量表达式>< ‘]‘>  | < ‘(‘>< ‘)‘>  | < ‘(‘><参数类型列表><‘)‘>  |<  直接抽象说明符><‘(‘>< ‘)‘>  | <直接抽象说明符><‘(‘><参数类型列表><‘)‘>

<有标号语句>→<标识符><‘:><‘语句> |  <CASE常量表达式><‘:‘><语句 > | < DEFAULT><‘:‘><语句>

时间: 2024-12-24 23:49:27

c语言文法定义的相关文章

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

1014 C语言文法定义与C程序的推导过程  程序:冒泡算法C程序(语法树)1 阅读并理解提供给大家的C语言文法文件. 2 参考该文件写出一个自己好理解版的现实版的完整版的C语言文法. 3 给出一段C程序,画出用上述文法产生这段C程序的完整语法树. 程序:冒泡算法C程序 点此文字查看原图(完整图片) 1 #include <stdio.h> 2 3 main() 4 { 5 int i,j,temp; 6 int a[10]; 7 8 for(i=0;i<10;i++) 9 scanf

C语言文法定义及推导

文法推导如下: <程序>→ <外部声明>|<程序><外部声明><外部声明>→ <函数定义>|<声明><函数定义>→ <类型说明><声明符><复合语句><类型说明>→void|char|int|float...<声明符>→<指针直接说明符>|<直接声明符><指针>→<*>|<* *><直接

1014 C语言文法定义与C程序的推导过程

<程序>-><外部声明>|<程序><外部声明> <外部声明>-><函数定义>|<定义> <函数定义>-><类型说明><声明><复合语句> <类型说明>->无返回型|字符型|整型|单精度型 <声明>-><指针直接说明符>|<直接说明符> <指针>-><’*’>|<’

1014--C语言文法定义

<程序>-><外部声明>|<程序><外部声明> <外部声明>-><函数定义>|<定义> <函数定义>-><类型说明><声明><复合语句> <类型说明>->无返回型|字符型|整型|单精度型 <声明>-><指针直接说明符>|<直接说明符> <指针>-><’*’>|<’

1029 C语言文法定义

program à external_declaration | program external_declaration <源程序> ->  <外部声明> |  <源程序>  <外部声明> external_declaration à function_definition | declaration <外部声明>  ->   <函数定义>  |  <声明> function_definition à typ

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

program à external_declaration | program external_declaration <程序> ->  <外部声明> |  <程序>  <外部声明> external_declaration à function_definition | declaration <外部声明>  ->   <函数定义>  |  <声明> function_definition à type_

C语言文法定义及C程序的推导过程

program à external_declaration | program external_declaration <程序> ->  <外部声明> |  <程序>  <外部声明> external_declaration à function_definition | declaration <外部声明>  ->   <函数定义>  |  <声明> function_definition à type_

1014 我的C语言文法定义与C程序推导过程

程序> -> <外部声明> | <程序> <外部声明> <外部声明> -> <函数定义> | <声明> <函数定义> -> <类型说明> <声明符> <复合语句> <类型说明> -> <void> | <char> | <int>|<float> <声明> ->  <指针&g

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

program à external_declaration | program external_declaration 程序→ <外部声明> | <程序> <外部声明> external_declaration à function_definition | declaration       外部声明→ <函数定义> | <声明> function_definition à type_specifier declarator compoun