LCC编译器的源程序分析(26)逗号表达式
2007-06-04 21:18
246 查看
逗号表达式是优先级最低的表达式。像下面的例子:
1+2,2+3;
a = (a,b,c);
还有在for语句中的使用:
for(int a=3,b=4; a < 10; a++,b++)
{
}
要处理上面这些逗号表达式,在LCC里就需调用表达式处理函数expr,它的代码如下:
#001 Tree expr(int tok)
#002 {
#003 static char stop[] = { IF, ID, '}', 0 };
#004
#005 Tree p = expr1(0);
#006
#007 while (t == ',')
#008 {
#009 Tree q;
#010 t = gettok();
#011 q = pointer(expr1(0));
#012 p = tree(RIGHT, q->type, root(value(p)), q);
#013 }
#014
#015 if (tok)
#016 test(tok, stop);
#017
#018 return p;
#019 }
在第3行里是定义了出错时找到下一个恢复错误的符号。
第5行是处理逗号表达式的第一个表达式。
第7行是循环地处理所有逗号表达式。
第11行是处理下一个表达式。
第12行是构造逗号表达式树。
第16行是找到下一个出错恢复的位置。
它处理逗号表达式主要是递归地调用前面介绍的表达式函数来分析逗号表达式。
从前面几节到这里把所有表达式介绍完成,主要介绍局部变量初始化时需要表达式运算,才能计算右边的值,然后再赋值给定义的变量。下一节开始分析C语言的语句了。
1+2,2+3;
a = (a,b,c);
还有在for语句中的使用:
for(int a=3,b=4; a < 10; a++,b++)
{
}
要处理上面这些逗号表达式,在LCC里就需调用表达式处理函数expr,它的代码如下:
#001 Tree expr(int tok)
#002 {
#003 static char stop[] = { IF, ID, '}', 0 };
#004
#005 Tree p = expr1(0);
#006
#007 while (t == ',')
#008 {
#009 Tree q;
#010 t = gettok();
#011 q = pointer(expr1(0));
#012 p = tree(RIGHT, q->type, root(value(p)), q);
#013 }
#014
#015 if (tok)
#016 test(tok, stop);
#017
#018 return p;
#019 }
在第3行里是定义了出错时找到下一个恢复错误的符号。
第5行是处理逗号表达式的第一个表达式。
第7行是循环地处理所有逗号表达式。
第11行是处理下一个表达式。
第12行是构造逗号表达式树。
第16行是找到下一个出错恢复的位置。
它处理逗号表达式主要是递归地调用前面介绍的表达式函数来分析逗号表达式。
从前面几节到这里把所有表达式介绍完成,主要介绍局部变量初始化时需要表达式运算,才能计算右边的值,然后再赋值给定义的变量。下一节开始分析C语言的语句了。
相关文章推荐
- [转载]LCC编译器的源程序分析(26)逗号表达式
- LCC编译器的源程序分析(26)逗号表达式
- LCC编译器的源程序分析(22)基本表达式
- LCC编译器的源程序分析(28)函数表达式语句
- LCC编译器的源程序分析(41)赋值表达式的有向无环图
- [转载]LCC编译器的源程序分析(22)基本表达式
- LCC编译器的源程序分析(41)赋值表达式的有向无环图
- LCC编译器的源程序分析(43)赋值表达式的有向无环图
- [转载]LCC编译器的源程序分析(23)一元运算表达式
- LCC编译器的源程序分析(43)赋值表达式的有向无环图
- [转载]LCC编译器的源程序分析(24)条件表达式
- LCC编译器的源程序分析(23)一元运算表达式
- LCC编译器的源程序分析(43)赋值表达式的有向无环图
- [转载]LCC编译器的源程序分析(25)赋值表达式
- LCC编译器的源程序分析(23)一元运算表达式
- [转载]LCC编译器的源程序分析(41)赋值表达式的有向无环图
- LCC编译器的源程序分析(24)条件表达式
- LCC编译器的源程序分析(42)赋值表达式的有向无环图
- LCC编译器的源程序分析(24)条件表达式
- LCC编译器的源程序分析(42)赋值表达式的有向无环图