浅谈Switch与If

简介: 浅谈Switch与If

1.switch case与if else的效率问题

1.1 .switch case与if else的区别:

switch case会生成一个跳转表来指示实际的case分支的地址(可以理解成随机查找O(1)),而if...else却需要遍历条件分支直到命中条件(可以理解成二分查找O(logN))

1.2. switch case的优缺点

(1)switch case的优点:

当分支较多时,用switch的效率是很高的。因为switch是确定了选择值之后直接跳转到那个特定的分支.

(2)witch case的缺点:

  1. switch...case占用较多的代码空间,因为它要生成跳表,特别是当case常量分布范围很大但实际有效值又比较少的情况,switch...case的空间利用率将变得很低。
  2. switch...case只能处理case为常量的情况。

1.3. if else的优缺点

(1)if else的优点:if else能应用于更多的场所以if else比较灵活。

(2)if else的缺点:if else必须遍历所以得可能值。

总结:

在选择分支较多时,选用switch…case结构会提高程序的效率,但switch不足的地方在于只能处理字符或者数字类型的变量,if…else结构更加灵活一些,if…else结构可以用于判断表达式是否成立,比如if(a+b>c),if…else的应用范围更广,switch…case结构在某些情况下可以替代if…else结构。

2.switch不加break为什么具有直通性?

用break的作用就是跳出switch,不执行其他的case,如果不加就一直走下去,一直等到下一个break后跳出,如果一直没有break,就要等到switch结束后退出。

相关文章
|
4月前
|
编译器
switch 语句
switch 语句
40 3
|
2月前
|
Java
switch的使用
这段 Java 代码首先提示用户输入一个代表月份的数字。通过 `Scanner` 类从键盘接收输入后,使用 `switch` 语句根据输入的数字来判断所属季节并输出相应的信息。例如,1、2 或 12 月为冬季。若输入不在 1 至 12 的范围内,则输出错误信息。此外,还展示了仅针对单个特定月份(如 1 月)进行匹配的简化示例。 ```markdown - 提示用户输入月份。 - 使用 `Scanner` 获取输入。 - 通过 `switch` 语句根据输入判断季节。 - 输出对应季节或错误信息。 - 展示了处理单个和多个月份的 `case` 示例。 ```
24 4
|
Java 编译器 C语言
【C/C++】 switch-case 详解/全面总结
关于 C语言/C++ 中,switch-case 的尽量详细和全面的解释与总结
633 0
if-else if与switch的区别
if-else if与switch的区别
105 0
enum和switch case结合使用
在将enum和switch case结合使用的过程中,遇到了这个错误:“An enum switch case label must be the unqualified name of an enumeration constant”。
switch case 执行
switch case 执行
117 0
|
Dart
Dart之break、continue/ switch...case
Dart之break、continue/ switch...case
104 0
Dart之break、continue/ switch...case
|
C#
switch case语句
switch case语句
167 0
switch—case需要注意的点
switch—case需要注意的点
227 0
switch—case需要注意的点