Switch语句的工作原理

switch语句如何立即下降到内存中的正确位置?对于嵌套的if语句,它必须与每个语句进行比较,但是使用switch语句它会直接转到正确的大小写.这是如何实现的?

解决方法

将switch语句编译为机器代码有许多不同的方法.以下是一些:

>编译器可以生成一系列测试,这些测试效率不高,因为只有log2(N)测试足以在N个可能的情况下调度值.
>编译器可以生成一个值表和跳转地址,然后由通用查找代码(线性或二分法,类似于bsearch())使用,最后跳转到相应的位置.
>如果案例值足够密集,编译器可以生成一个跳转地址表和代码,用于检查开关值是否在包含所有案例值的范围内,并直接跳转到相应的地址.这可能是最接近您的描述的实现:但是使用switch语句,它直接转到正确的大小写.

根据目标cpu的特定能力,编译器设置以及案例值的数量和分布,编译器可能使用上述方法之一或其他方法,或它们的组合,甚至一些其他方法.

编译器设计人员花费了大量精力来尝试改进这些选择的启发式方法.查看汇编输出或使用Godbolt’s Compiler Explorer等在线工具查看各种代码生成可能性.

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...