微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Switch语句的工作原理

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

解决方法

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

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

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

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

原文地址:https://www.jb51.cc/c/116263.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐