LCC编译器的源程序分析(36)case语句

来源:互联网 发布:mac mini评测视频 编辑:程序博客网 时间:2024/06/02 00:45
case语句是使用在switch语句之中,它实现了选择一个分支执行。当表达式的值与case后面的常量表达式的值相等时,就执行此case语句后面的语句。LCC处理这个语句的代码如下:
#001 case CASE:    
#002         {
#003               int lab = genlabel(1);
#004               if (swp == NULL)
#005                    error("illegal case label/n");
#006 
#007               definelab(lab);
 
3行生成标号1起始值。
4行是判断是否在switch语句中,如果不在就在第5行里提示出错。
7行是生成标号1
 
下面开始循环处理所有case语句。
#008               while (t == CASE)
#009               {
#010                    static char stop[] = { IF, ID, 0 };
#011                    Tree p;
#012                    t = gettok();
#013                    p = constexpr(0);
#014                    if (generic(p->op) == CNST && isint(p->type))
#015                    {
#016                          if (swp)
#017                          {
#018                               needconst++;
#019                               p = cast(p, swp->sym->type);
#020                               if (p->type->op == UNSIGNED)
#021                                     p->u.v.i = extend(p->u.v.u, p->type);
#022                               needconst--;
#023                               caselabel(swp, p->u.v.i, lab);
#024                          }
#025                    }
#026                    else
#027                          error("case label must be a constant integer expression/n");
#028 
#029                    test(':', stop);
#030               }
12行是获取下一个记号。
13行是处理case语句后面的常量表达式,它是通过函数constexpr来处理的。
14行到第27行都是处理常量表达式的类型,如果不是就会出错提示。
 
 
#031               statement(loop, swp, lev);
#032         }
#033         break;
31行是处理case后面的语句,它是递归调用函数statement来处理。
 
通过上面这段代码,就处理完成一个case语句。它是先定义一个标号,计算常量表达式,并判断常量表达式的类型,最后处理语句。
 
原创粉丝点击