C语言:case详解
C语言虽然没有限制 if else 能够处理的分支数量,但当分支过多时,用 if else 处理会不太方便,而且容易出现 if else 配对出错的情况。例如,输入一个整数,输出该整数对应的星期几的英文表示:
- #include <stdio.h>
- int main(){
- int a;
- printf("Input integer number:");
- scanf("%d",&a);
- if(a==1){
- printf("Monday\n");
- }else if(a==2){
- printf("Tuesday\n");
- }else if(a==3){
- printf("Wednesday\n");
- }else if(a==4){
- printf("Thursday\n");
- }else if(a==5){
- printf("Friday\n");
- }else if(a==6){
- printf("Saturday\n");
- }else if(a==7){
- printf("Sunday\n");
- }else{
- printf("error\n");
- }
- return 0;
- }
运行结果:
Input integer number:3
Wednesday
对于这种情况,实际开发中一般使用 switch 语句代替,请看下面的代码:
- #include <stdio.h>
- int main(){
- int a;
- printf("Input integer number:");
- scanf("%d",&a);
- switch(a){
- case 1: printf("Monday\n"); break;
- case 2: printf("Tuesday\n"); break;
- case 3: printf("Wednesday\n"); break;
- case 4: printf("Thursday\n"); break;
- case 5: printf("Friday\n"); break;
- case 6: printf("Saturday\n"); break;
- case 7: printf("Sunday\n"); break;
- default:printf("error\n"); break;
- }
- return 0;
- }
运行结果:
Input integer number:4
Thursday
switch 是另外一种选择结构的语句,用来代替简单的、拥有多个分枝的 if else 语句,基本格式如下:
switch(表达式){
case 整型数值1: 语句 1;
case 整型数值2: 语句 2;
......
case 整型数值n: 语句 n;
default: 语句 n+1;
}
它的执行过程是:
1) 首先计算“表达式”的值,假设为 m。
2) 从第一个 case 开始,比较“整型数值1”和 m,如果它们相等,就执行冒号后面的所有语句,也就是从“语句1”一直执行到“语句n+1”,而不管后面的 case 是否匹配成功。
3) 如果“整型数值1”和 m 不相等,就跳过冒号后面的“语句1”,继续比较第二个 case、第三个 case……一旦发现和某个整型数值相等了,就会执行后面所有的语句。假设 m 和“整型数值5”相等,那么就会从“语句5”一直执行到“语句n+1”。
4) 如果直到最后一个“整型数值n”都没有找到相等的值,那么就执行 default 后的“语句 n+1”。
需要重点强调的是,当和某个整型数值匹配成功后,会执行该分支以及后面所有分支的语句。例如:
- #include <stdio.h>
- int main(){
- int a;
- printf("Input integer number:");
- scanf("%d",&a);
- switch(a){
- case 1: printf("Monday\n");
- case 2: printf("Tuesday\n");
- case 3: printf("Wednesday\n");
- case 4: printf("Thursday\n");
- case 5: printf("Friday\n");
- case 6: printf("Saturday\n");
- case 7: printf("Sunday\n");
- default:printf("error\n");
- }
- return 0;
- }
运行结果:
Input integer number:4
Thursday
Friday
Saturday
Sunday
error
输入4,发现和第四个分支匹配成功,于是就执行第四个分支以及后面的所有分支。这显然不是我们想要的结果,我们希望只执行第四个分支,而跳过后面的其他分支。为了达到这个目标,必须要在每个分支最后添加break;
语句。
break 是C语言中的一个关键字,专门用于跳出 switch 语句。所谓“跳出”,是指一旦遇到 break,就不再执行 switch 中的任何语句,包括当前分支中的语句和其他分支中的语句;也就是说,整个 switch 执行结束了,接着会执行整个 switch 后面的代码。
使用 break 修改上面的代码:
- #include <stdio.h>
- int main(){
- int a;
- printf("Input integer number:");
- scanf("%d",&a);
- switch(a){
- case 1: printf("Monday\n"); break;
- case 2: printf("Tuesday\n"); break;
- case 3: printf("Wednesday\n"); break;
- case 4: printf("Thursday\n"); break;
- case 5: printf("Friday\n"); break;
- case 6: printf("Saturday\n"); break;
- case 7: printf("Sunday\n"); break;
- default:printf("error\n"); break;
- }
- return 0;
- }
运行结果:
Input integer number:4
Thursday
由于 default 是最后一个分支,匹配后不会再执行其他分支,所以也可以不添加break;
语句。
最后需要说明的两点是:
1) case 后面必须是一个整数,或者是结果为整数的表达式,但不能包含任何变量。请看下面的例子:
- case 10: printf("..."); break; //正确
- case 8+9: printf("..."); break; //正确
- case 'A': printf("..."); break; //正确,字符和整数可以相互转换
- case 'A'+19: printf("..."); break; //正确,字符和整数可以相互转换
- case 9.5: printf("..."); break; //错误,不能为小数
- case a: printf("..."); break; //错误,不能包含变量
- case a+10: printf("..."); break; //错误,不能包含变量
2) default 不是必须的。当没有 default 时,如果所有 case 都匹配失败,那么就什么都不执行。
C语言:case详解的更多相关文章
- 深入理解C语言 - 指针详解
一.什么是指针 C语言里,变量存放在内存中,而内存其实就是一组有序字节组成的数组,每个字节有唯一的内存地址.CPU 通过内存寻址对存储在内存中的某个指定数据对象的地址进行定位.这里,数据对象是指存储在 ...
- c++、Java、python对应的编译型语言和解释性语言区别详解
1.首先明确一点: 高级语言是不能直接在CPU上运行的.CPU只能处理机器语言,就是黑客帝国里面那个10101010101110的数字流. 那么为了让机器语言能够在CPU上运行,那么就必须将其变成机器 ...
- 小程序脚本语言WXS详解
WXS脚本语言是 Weixin Script脚本的简称,是JS.JSON.WXML.WXSS之后又一大小程序内部文件类型.截至到目前小程序已经提供了5种文件类型. 解构小程序的几种方式,其中一种方式就 ...
- Go语言interface详解
interface Go语言里面设计最精妙的应该算interface,它让面向对象,内容组织实现非常的方便,当你看完这一章,你就会被interface的巧妙设计所折服. 什么是interface 简单 ...
- C语言关键字详解
相对于其他语言来说,C语言的关键字算是少的了.在C98中关键子总共只有32个,我们来分析一下每个关键字在C语言中它独特的作用. 1.关于数据类型的关键字 (1) char :声明字符型变量或函数 ( ...
- C语言指针详解
前言 这不是我第一次写关于C指针的文章了,只是因为指针对于C来说太重要,而且随着自己编程经历越多,对指针的理解越多,因此有了本文. 为什么需要指针? 指针解决了一些编程中基本的问题. 第一,指针的使用 ...
- GO语言slice详解(结合源码)
一.GO语言中slice的定义 slice 是一种结构体类型,在源码中的定义为: src/runtime/slice.go type slice struct { array unsafe.Point ...
- C语言正则表达式详解 regcomp() regexec() regfree()详解
标准的C和C++都不支持正则表达式,但有一些函数库可以辅助C/C++程序员完成这一功能,其中最著名的当数Philip Hazel的Perl-Compatible Regular Expression库 ...
- Canny边缘检测算法原理及C语言实现详解
Canny算子是John Canny在1986年提出的,那年老大爷才28岁,该文章发表在PAMI顶级期刊上的(1986. A computational approach to edge detect ...
随机推荐
- publicPath路径问题
output: { filename: "[name].js", path:path.resolve(__dirname,"build") } 如果没有指定pu ...
- 聊聊 apt sources.list 文件格式
前言 之前玩 ubuntu 需要切换国内源地址时,都是网上复制别人提供好的,也不知道是什么意思,拿来就用. 这次花点时间来看一下 apt sources.list 的格式,以及其表示的含义. 格式 s ...
- Xilinx FPGA全局介绍
Xilinx FPGA全局介绍 现场可编程门阵列 (FPGA) 具有诸多特性,无论是单独使用,抑或采用多样化架构,皆可作为宝贵的计算资产:许多设计人员并不熟悉 FPGA,亦不清楚如何将这类器件整合到设 ...
- GPU编程和流式多处理器(四)
GPU编程和流式多处理器(四) 3.2. 单精度(32位) 单精度浮点支持是GPU计算的主力军.GPU已经过优化,可以在此数据类型上原生提供高性能,不仅适用于核心标准IEEE操作(例如加法和乘法),还 ...
- DHCP的原理与配置
DHCP 动态主机配置协议(Dynamic Host Configuration Protocol) 可以减少管理员的工作量 避免用户手工配置网络参数时造成的地址冲突 DHCP报文类型: 报文类型 ...
- 尚硅谷Java——宋红康笔记【day6-day10】
day6 一.数组的概述 1.数组的理解:数组(Array),是多个相同类型数据按一定顺序排列的集合,并使用一个名字命名,并通过编号的方式对这些数据进行统一管理. 2.数组相关的概念: 数组名 元素 ...
- 微信小程序 -- 基于 movable-view 实现拖拽排序
微信小程序 -- 基于 movable-view 实现拖拽排序 项目基于colorui样式组件 ColorUI组件库 (color-ui.com) 1.实现效果 2. 设计思路 movable-vie ...
- python学习笔记01-简单接触
前言:陆陆续续学习python一年多了,每次都因为各种原因中断了,希望这次可以通过记录更新的方式坚持学完一轮. 简单了解python Python是一种解释型.面向对象.动态数据类型的高级程序设计语言 ...
- .NET Core/.NET5/.NET6 开源项目汇总3:工作流组件
系列目录 [已更新最新开发文章,点击查看详细] 开源项目是众多组织与个人分享的组件或项目,作者付出的心血我们是无法体会的,所以首先大家要心存感激.尊重.请严格遵守每个项目的开源协议后再使用.尊 ...
- 【题解】ball 数论
题目 题目描述: 众所周知的是Dr.Bai 穷困潦倒负债累累,最近还因邦邦的出现被班上的男孩子们几乎打入冷宫,所以Dr.Bai 决定去打工赚钱. Dr.Bai 决定做玩♂球的工作,工作内容如下. 老板 ...