switch的一些思考(seitch与ifelse的区别)
参考博客:
https://www.cnblogs.com/balingybj/p/5751707.html
Switch的思考
Switch与If--else的比较
switch...case与if...else的根本区别在于,
switch...case会生成一个跳转表来指示实际的case分支的地址,而这个跳转表的索引号与switch变量的值是相等的。从而,switch...case不用像if...else那样遍历条件分支直到命中条件,而只需访问对应索引号的表项从而到达定位分支的目的。
具体地说:
- switch...case会生成一份大小(表项数)为最大case常量+1的跳表,
- 程序首先判断switch变量是否大于最大case 常量,若大于,则跳到default分支处理;
- 否则取得索引号为switch变量大小的跳表项的地址(即跳表的起始地址+表项大小*索引号)(类似与ArrayList实现了RandomAccess随机访问接口)
- 程序接着跳到此地址执行,到此完成了分支的跳转。
由此看来,switch有点以空间换时间的意思,而事实上也的确如此。
1.当分支较多时,当时用switch的效率是很高的。因为switch是随机访问的,就是确定了选择值之后直接跳转到那个特定的分支,但是if...else是遍历所以得可能值,知道找到符合条件的分支。如此看来,switch的效率确实比ifelse要高的多。
2.由上面的汇编代码可知道,switch...case占用较多的代码空间,因为它要生成跳表,特别是当case常量分布范围很大但实际有效值又比较少的情况,switch...case的空间利用率将变得很低。
3.switch...case只能处理case为常量的情况,对非常量的情况是无能为力的。例如 if (a > 1 && a < 100),是无法使用switch...case来处理的。所以,switch只能是在常量选择分支时比ifelse效率高,但是ifelse能应用于更多的场合,ifelse比较灵活。
JDK1.5 switch中枚举(Enum)的使用
JDK1.5 之前,switch语句支持的数据类型有byte、short、int、char.
在JDK1.5之后,增加了枚举类型,枚举类型可以对状态常量进行统一的整理,并且添加基本属性。
枚举也可以更在Sewitch后面,原因是switch先计算变量的排序值,然后与枚举常量的每个排序值进行对比,当变量为空时,调用ordinal方法报空指针异常。所以对于安全性要求高的代码需要判断。
switch(s) =s.ordinal;
jdk1.7 Switch中Spring的使用
在Java 7中,增加了对String类型的支持:实现的机制是根据字符串的哈希值匹配。下图是原文件编译前,和编译后,
Java和class文件的对比。
可以看出将字符串的switch转换为两个switch处理,通过哈希值匹配到数据,通过定义的byte变量在swit到具体的代码快执行。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构