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
語句。它是先定義一個標號,計算常量表達式,并判斷常量表達式的類型,最后處理語句。
?
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
