switch case语法

article/2025/10/2 20:30:47

文章目录

  • switch case组合
  • 不要拿青龙偃月刀去削苹果
  • case的作用是什么?
  • break的作用是什么?
  • case后面的值有什么要求吗?
  • case语句的排列顺序问题
  • default语句相关问题
  • 使用case语句的一些注意事项

switch case组合

基本语法结构

switch(整型常量/整型变量/整型表达式){case var1:break;case var2:break;case var2:break;default:break;
}

不要拿青龙偃月刀去削苹果

既然已经有了if else分支语句,那为什么还要switch 语句呢?

switch 语句也是一种分支语句,常常用于多分支的情况。这种多分支,一般指的是很多很多分支,而且判定条件主要以整型为主:

如:输入数字,输出相应的星期几

#include <stdio.h>
int main()
{int day = 0;do{printf("请输入:>");scanf("%d", &day);switch (day) {case 1:printf("星期一\n");break;case 2:printf("星期二\n");break;case 3:printf("星期三\n");break;case 4:printf("星期四\n");break;case 5:printf("星期五\n");break;case 6:printf("星期六\n");break;case 7:printf("星期七\n");break;case 0:printf("退出\n");break;default:printf("输入错误,请重新输入\n");break;} while (day);return 0;
}

以上的程序,如果用if else来写,会非常的繁琐!

case的作用是什么?

case本质是进行判定功能,与switch里面的语句相比较,如果相同,则执行语句,不相同则找下一个case比较,直至所有case语句都不与switch相同,此时执行default语句。

image-20220603215700927

case决定了从哪开始执行语句,所以说case是判定功能

break的作用是什么?

break本质是执行分支功能

具体效果看上面图片

那如果没有break会发生什么呢?

#include <stdio.h>
int main()
{int day = 0;do{printf("请输入:>");scanf("%d", &day);switch (day) {case 1:printf("星期一\n");case 2:printf("星期二\n");case 3:printf("星期三\n");case 4:printf("星期四\n");case 5:printf("星期五\n");break;case 6:printf("星期六\n");break;case 7:printf("星期七\n");break;case 0:printf("退出\n");break;default:printf("输入错误,请重新输入\n");break;}} while (day);return 0;
}

我们删除了1-4break,看效果

image-20220603220227329

可以看到,当我们输入1的时候,case 1开始执行,然后case 2竟然也执行了,后续也执行,直到星期五结束后,没再执行。

当我们输入2的时候,从case 2开始执行,直到星期五结束。

可以发现,1-4没有break,而5break,所以输出星期五执行,再执行break,就不再执行下面的语句了。

这恰恰说明了上面case的作用:决定了从哪开始执行语句。

但是现在的重点是break,可以发现当没有break时,会继续执行下一条case语句,当遇到break时,不再执行。

这恰恰就是break的分支功能。

其实switch语句是没有任何功能的,真正使得switch结构实现类似if else功能的是由于casebreak语句的配合。

上面的程序还可以改造成如下:

//这就是多个不同的case,想执行同一条语句的做法
#include <stdio.h>
int main()
{int day = 0;do{printf("请输入:>");scanf("%d", &day);switch (day) {case 1:case 2:case 3:case 4:case 5:printf("周内\n");break;case 6:case 7:printf("周末\n");break;case 0:printf("退出\n");break;default:printf("输入错误,请重新输入\n");break;}} while (day);return 0;
}

image-20220603221102287

关于break还有一个很容易混淆的地方,就是一般人在一般情况下在case后面要么不写break,要么只写break,万不得已不要写其它,特别是return,极易有可能使得用户在调试时忽略,从而不能发现问题所在!!!

case后面的值有什么要求吗?

switch语句必须是整型常量/整型变量/整型表达式

不能够是有效的布尔值,

int x = 10;
switch (0 == x)//因为这样得表达式,结果只有0/1,下面的case也只能是0/1才能够与之匹配
{
default:break;
}

case语句必须是整型常量/整型常量表达式,类似const修饰的常量称为只读变量也不可以!

image-20220603222100891

case语句的排列顺序问题

按字母或数字顺序排列各条case语句

就像上面的程序,当所有case语句作用相当,没有什么特别的重要性差别时,一般按顺序排列case语句,像1、2、3、4或者A、B、C、D等等。

把正常情况放在前面,而把异常情况放在后面

也如同上面的程序,我们把正常的星期一到星期七写在前面,而把退出写在最后。

按执行频率排列case语句

将使用频率高的case语句放在前面,就如同把畅销货放在售卖最显眼的地方一样。这样可以使得我们在调试(一般是频率较高的)时,能快速的找到该case语句。

default语句相关问题

先说一句,default语句可写可不写,但是,强烈建议无论如何都写上。这就谈到default语句的作用了。

作用:当所有的case语句都不与switch语句匹配时,这时执行default语句。强烈建议写在最后!!!

default语句的位置是非常自由的

image-20220603224310309

但是有一点,当case入口已开启,且没有break,且default紧随其后,也是会执行default语句的

image-20220603224514923

但是还要再说一遍:强烈建议无论如何都加上default语句,并且写在最后!!!

使用case语句的一些注意事项

简化每种情况对应的操作

也就是说,在case语句和break语句中间的语句,越简洁越好,

#include <stdio.h>
int main()
{int n = 0;scanf("%d", &n);switch (n){case 1:printf("hello world!\n");printf("hello world!\n");printf("hello world!\n");printf("hello world!\n");break;case 2:break;case 3:break;default:break;}return 0;
}

假设case中有四条语句,尽量将这些语句封装成一个函数,使得case中的语句尽量简洁

#include <stdio.h>
void show() {printf("hello world!\n");printf("hello world!\n");printf("hello world!\n");printf("hello world!\n");
}
int main()
{int n = 0;scanf("%d", &n);switch (n){case 1:show();break;case 2:break;case 3:break;default:break;}return 0;
}

还有一点,在case后定义变量是不可以的,如果非要定义变量,那么就得加{}

image-20220604082852335

当然了,即使是这样的写法,也是非常不建议的,强烈建议封装成函数!!!
不要为了使用case语句而刻意制造一个变量

#include <stdio.h>
int main()
{for (int i = 0; i < 10; i++) {int tmp = i;//这里的tmp就是刻意制造的变量,非常不建议这样干switch (tmp){default:break;}}return 0;
}

应该是这样

#include <stdio.h>
int main()
{for (int i = 0; i < 10; i++) {switch (i)//这样会比上面好很多{default:break;}}return 0;
}

default子句只用于检查真正的默认情况

有时候,只剩下最后一种情况需要处理,但是你却偷懒,没有用case处理这种情况,而是交给了default,这样是非常不妥的,比如说,上面那个星期一到星期七的程序,我们只用case处理了星期一至六,而把星期七交给了default是非常不好的。因为这样将失去case语句的标号所提供的自说明功能,而且丧失了使用default子句处理错误情况的能力。所以我们不能够偷懒去少写代码,而应该真正用case处理每一种情况,而将真正的默认情况交给defualt比如说输入错误。


http://chatgpt.dhexx.cn/article/3yCgmlny.shtml

相关文章

SQL中case的使用方法

Case具有两种格式。简单Case函数和Case搜索函数。 1.简单Case函数 CASE sex WHEN 1 THEN 男WHEN 2 THEN 女 ELSE 其他 END2.Case搜索函数 CASE WHEN sex 1 THEN 男WHEN sex 2 THEN 女ELSE 其他 END3.简单case函数 VS case搜索函数 这两种方式&#xff0c;可以实现相同的功…

[转载]常用CASE工具介绍

[转载]常用CASE工具介绍转载自&#xff1a;http://www.cnblogs.com/powerlc/archive/2006/01/12/315959.html 一&#xff0c;概述 今天, 代码变得日益简单, 在Model的指导下, 思想, 设计, 分析都变得异常重要。企业业务建模工具, 产品非常多, 特别是在MDA日益流行的今天. Work…

CASE语句的使用方法

CASE语句有两种&#xff1a; 一种是case [column] when&#xff0c;指定了判断条件所在的列。 另一种是case when [column]&#xff0c;因为条件在子句中所以能对任意列进行判断。 本例建立一个员工表&#xff0c;有员工id&#xff08;id&#xff09;&#xff0c;员工姓名&am…

常用CASE工具介绍 ZZ

常用CASE工具介绍 一&#xff0c;概述  今天, 代码变得日益简单, 在Model的指导下, 思想, 设计, 分析都变得异常重要。企业业务建模工具, 产品非常多, 特别是在MDA日益流行的今天. WorkFlow是典型的业务及流程建模。 二&#xff0c;软件开发CASE工具简介   (一)图稿绘制&…

CASE 工具有哪些

CASE 工具 CASE工具设置的软件应用程序。这使用为自动的SDLC活动。 CASE工具所使用的软件项目经理,分析师和工程师开发的软件系统. 有许多CASE工具做软件开发生命周期的各个阶段,如工具,设计工具,项目管理工具,数据库管理工具,文档工具分析. 为了得到所需的结果,CASE工具…

网络:简述路由算法之动态路由算法

网络&#xff1a;简述路由算法之动态路由算法 在计算机网络中&#xff0c;路由器的一个很重要责任就是要在端对端的节点中找出一条最佳路径出来&#xff0c;通过自己与相邻节点之间的信息&#xff0c;来计算出从自己位置到目的节点之间的最佳线路&#xff0c;这种算法我们可以理…

路由选择算法——链路状态算法

好久没写东西了&#xff0c;好生疏的感觉。。 链路状态算法 这是一种全局式的路由选择算法&#xff0c;也就是说&#xff0c;一个路由器知道到其他路由器的所有链路的状态信息&#xff08;例如某条链路上堵不堵&#xff09;&#xff0c;并且假设这种信息是被量化好了的&#…

示例演示“距离矢量路由算法”工作原理

以下内容摘自刚刚上市&#xff0c;已被纳入全国高校教材系统&#xff0c;并在全国热销、好评如潮的《深入理解计算机网络》新书。 7.5.3 距离矢量路由算法 现代计算机网络通常使用动态路由算法&#xff0c;因为这类算法能够适应网络的拓扑和流量变化&#xff0c;其中最流行的…

距离矢量路由算法

现代计算机网络通常使用动态路由算法&#xff0c;因为这类算法能够适应网络的拓扑和流量变化&#xff0c;其中最流行的两种动态路由算法是“距离矢量路由算法”和“链路状态路由算法”。 距离矢量路由算法&#xff08;Distance Vector Routing&#xff0c;DV&#xff09;是ARPA…

路由算法之距离矢量算法和链路状态算法

我们之前说了&#xff0c;路由器需要对于每一对端端节点都要寻找出一个最佳的路径&#xff0c;比如说最小链路成本的路径。路由算法就是通过自己到相邻节点之间的信息来计算出自己到目的地址的最佳出境线路是哪一条&#xff0c;进而进行转发的一类算法。具有代表性的就是距离矢…

路由算法(网络层)

引言 网络层的主要功能是将数据包从源机器路由到目标机器。在大多数是网络中&#xff0c;数据包需要多跳才能到达目的地。唯一一个值得指出的例外是广播网络&#xff0c;但即使在广播网络中&#xff0c;如果源机器和目标机器不在同一个网络段中时&#xff0c;路由仍然是一个问…

路由算法(凑字)

即最短路径问题&#xff0c;说白了还是算法问题&#xff0c;分类有静态动态路由算法&#xff0c;和全局分散路由算法两种。 **静态&#xff1a;**通过手工配置&#xff0c;路由更新慢&#xff0c;但是优先级高。 **动态&#xff1a;**路由更新快&#xff08;定期更新&#xff0…

最佳路由路径选择算法详解

动态路由协议基于运行特征可分为 距离矢量协议&#xff1a;RIP、EIGRP、BGP 链路状态协议&#xff1a;OSPF、ISIS 通用的路由选择算法 1.最长匹配原则 2.管理距离 3.度量值 路由路径选择的时候&#xff0c;最先看最长匹配原则&#xff0c;然后再看管理距离&#xff0c;最…

路由算法

距离矢量路由算法&#xff08;D-V&#xff09; Distance vector routing:动态路由算法&#xff0c;最初应用于ARPANET&#xff0c;后来应用于因特网的RIP协议&#xff08;路由信息协议) &#xff0c;Cisco的IGRP和EIGRP路由协议也是采用DV这种路由算法的。 基本思想 每个结点…

4.2.1 路由算法与路由协议概述(静态路由和动态路由---距离-向量路由算法---链路状态路由算法、层次路由)

文章目录 0.思维导图1.路由算法分类与路由表2.静态路由和动态路由3.动态路由的两种算法&#xff1a;链路状态路由算法和距离向量路由算法4.层次路由 0.思维导图 1.路由算法分类与路由表 路由器转发分组是通过路由表转发的&#xff0c;而路由表是通过各种算法得到的。从能否随网…

路由算法-链路状态路由

路由算法 网络层的主要功能是将数据包从源机器路由到目标机器。在大多数网络中&#xff0c;数据包需要经过多跳才能到达目的地。路由算法和这些算法所用的数据结构是网络层设计的最主要内容。 可以这样想&#xff0c;路由器内部有两个进程。其中一个进程在每个数据包到达的时候…

路由器路由算法

互联网是由路由器连接的网络组合而成的。为了能让数据包正确达地到达目标主机&#xff0c;路由器必须在途中进行正确地转发。这种向“正确的方向”转发数据所进行的处理就叫做路由控制或路由。 路由器根据路由控制表&#xff08;Routing Table&#xff09;转发数据包。它根据所…

距离向量路由算法

一、距离向量路由算法特点 距离向量路由算法是一种迭代的、异步的和分布式的算法。 &#xff08;1&#xff09;分布式&#xff1a;每个节点都从其直接相连邻居接受信息&#xff0c;进行计算&#xff0c;再将计算结果分发给邻居。 &#xff08;2&#xff09;迭代&#xff1a;计…

分簇路由算法 LEACH算法

1.1 什么是分簇路由算法 在无线传感器网络路由算法中&#xff0c;分簇路由算法具有能量消耗低、稳定性高和扩展性好等优点。分簇路由算法中分簇就是分组&#xff0c;即按照特定的应用要求将网络中的所有节点分成不同的小组&#xff0c;每个小组就是一个簇。每个簇由一个簇头和多…

路由选择算法

网络层的主要功能是将分组从源端机器经选定的路由送到目的端机器。在大多数子网中&#xff0c;分组的整个旅途需经过多次转发。无线广播网络是惟一明显的例外。但即使在这里&#xff0c;如果源端和目的端在同一网络中&#xff0c;仍然有路由选择的问题&#xff1a;路由选择算法…