c语言中case的用法

2016-12-02

C语言是一门实践性和动手能力要求很高的大学主干课程,但是C语言实验课的教学一直不受重视,教学效果也不太理想。下面小编就跟你们详细介绍下c语言中case的用法,希望对你们有用。

c语言中case的用法如下:

“case常量表达式只是起语句标号作用,并不是该处进行条件判断。在执行switch语句时,根据switch的表达式,找到与之匹配的case语句,就从此case子句执行下去,不在进行判断,直到碰到break或函数结束为止。”

使用switch语句直接处理多个分支(当然包括两个分支).其一般形式为:

switch(表达式)

{

case 常量表达式1:

语句1;

break;

case 常量表达式2:

语句2;

break;

……

case 常量表达式n:

语句n;

break;

default:

语句n+1;

break;

}

switch语句的执行流程是:首先计算switch后面圆括号中表达式的值,然后用此值依次与各个case的常量表达式比较,若圆括号中表达式的值与某个case后面的常量表达式的值相等,就执行此case后面的语句,执行后遇break语句就退出switch语句;若圆括号中表达式的值与所有case后面的常量表达式都不等,则执行default后面的语句n+1,然后退出switch语句,程序流程转向开关语句的下一个语句.

以上是switch-case的正规写法,default语句总是写在最后。但是,如果把default语句间在了case的中间,执行的结果又是怎样的呢?笔者测试了一下几种有代表性的情况,把结果简单罗列如下:

A. 每个语句中break齐整

switch(c)

{

case '1':

printf("1n");

break;

default:

printf("defaultn");

break;

case '2':

printf("2n");

break;

case '3':

printf("3n");

break;

}

此种情况最为规整,default写在中间跟写在最后的效果一致。

B. default语句后没有break

switch(c)

{

case '1':

printf("1n");

break;

default:

printf("defaultn");

// break;

case '2':

printf("2n");

break;

case '3':

printf("3n");

break;

}

此种情况下,输入分别为 1、 2、 3、 4,对应的输出分别为 1、 2 、3、 default 2(换行省略了,实际运行时有换行的);即此种情况下遵循A中的执行顺序和一般的标号规则。

C. 最后一个case没有break

switch(c)

{

case '1':

printf("1n");

break;

default:

printf("defaultn");

break;

case '2':

printf("2n");

break;

case '3':

printf("3n");

// break;

}

此种情况下,输入分别为 1、 2、 3、 4,对应的输出分别为1、2、3、default.可见实际的运行效果并不等同于把default语句挪到最后的运行效果。否则,输入为3时,输出应该为 3 default.

D. default和最后一个case都没有break

switch(c)

{

case '1':

printf("1n");

break;

default:

printf("defaultn");

// break;

case '2':

printf("2n");

break;

case '3':

printf("3n");

// break;

}

由上面A,B,C三种情况的运行结果,我们可以推测出D这种情况的运行结果。当输入分别为 1、2、3、4时,输出为1、2、3、default 2. 结果与B的情况相同。

更多相关阅读

最新发布的文章