为什么 switch 语句执行效率比 if-else 语句高?

在我们学习流程控制语句时不难发现,很多情况下能使用 if-else 语句的地方我们都能够使用 switch 语句来代替。

有经验的开发者会建议我们,尽量使用 switch 语句来代替繁琐的 if-else。

这样做的原因:switch 语句的执行效率会比 if-else 语句高。

下面我们就写一个简单的程序来对其进行验证:

public class Demo {
    public static void main(String[] args) {
        String aaa = "aaa";
        long t1 = System.nanoTime();
        if("a".equals(aaa)){
            System.out.println(aaa);
        } else if ("b".equals(aaa)) {
            System.out.println(aaa);
        } else if ("c".equals(aaa)) {
            System.out.println(aaa);
        } else if ("d".equals(aaa)) {
            System.out.println(aaa);
        } else if ("e".equals(aaa)) {
            System.out.println(aaa);
        } else if ("f".equals(aaa)) {
            System.out.println(aaa);
        } else if ("g".equals(aaa)) {
            System.out.println(aaa);
        } else if ("h".equals(aaa)) {
            System.out.println(aaa);
        } else if ("i".equals(aaa)) {
            System.out.println(aaa);
        } else if ("j".equals(aaa)) {
            System.out.println(aaa);
        } else if ("k".equals(aaa)) {
            System.out.println(aaa);
        } else if ("l".equals(aaa)) {
            System.out.println(aaa);
        } else if ("m".equals(aaa)) {
            System.out.println(aaa);
        } else if ("n".equals(aaa)) {
            System.out.println(aaa);
        } else {
            System.out.println(aaa);
        }
        long t2 = System.nanoTime();
        System.out.println("if 语句执行时间: " + (t2 - t1));

        //switch语句测试代码:
        long tt1 = System.nanoTime();
        switch (aaa) {
            case "a":
                System.out.println(aaa);
                break;
            case "b":
                System.out.println(aaa);
                break;
            case "c":
                System.out.println(aaa);
                break;
            case "d":
                System.out.println(aaa);
                break;
            case "e":
                System.out.println(aaa);
                break;
            case "f":
                System.out.println(aaa);
                break;
            case "g":
                System.out.println(aaa);
                break;
            case "h":
                System.out.println(aaa);
                break;
            case "i":
                System.out.println(aaa);
                break;
            case "j":
                System.out.println(aaa);
                break;
            case "k":
                System.out.println(aaa);
                break;
            case "l":
                System.out.println(aaa);
                break;
            case "m":
                System.out.println(aaa);
                break;
            case "n":
                System.out.println(aaa);
                break;
            default:
                System.out.println(aaa);
                break;
        }
        long tt2 = System.nanoTime();
        System.out.println("switch 语句执行时间: " + (tt2 - tt1));
    }
}

输出:

aaa
if 语句执行时间: 201300
aaa
switch 语句执行时间: 18200

我们可以发现在这个程序中,swicth 语句的执行时间仅仅只有 if-else 语句的二十分之一。

从这个程序就足以体现出 switch 语句的高效性。

那么为什么 switch 语句会比 if-else 语句高效的这么多呢?

这是因为编译器在处理 switch 语句时,会生成一个跳转表,然后根据值之间进行跳转。然而对于 if-else 语句,编译器需要一个一个进行比较,直到找到结果。

从数据结构与算法的角度来看,switch 语句相当于一个数组,其查询时间复杂度为 O(1);而 if-lese 语句相当于一个链表,其时间复杂度为 O(n)

  • 6
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
switch语句if-else语句是C语言中的两种分支语句,它们有以下区别[^1]: 1. 语法结构不同:switch语句使用switch关键字,后面跟着一个整型表达式,然后是一系列的case语句;而if-else语句使用if关键字,后面跟着一个表达式,然后是一系列的语句块。 2. 判断条件不同:switch语句的判断条件是整型表达式,而if-else语句的判断条件可以是任意的表达式。 3. 执行方式不同:switch语句根据整型表达式的值来选择执行哪个case语句,一旦找到匹配的case语句,就会执行语句以及其后的所有语句,直到遇到break语句或者switch语句结束;而if-else语句是按照顺序判断条件,只会执行第一个满足条件的语句块,然后跳出整个if-else语句。 4. 适用场景不同:switch语句适用于多个固定值的判断,例如根据不同的整型值执行不同的操作;而if-else语句适用于根据不同的条件执行不同的操作,条件可以是任意的表达式。 下面是一个使用switch语句if-else语句的示例: 使用switch语句判断星期几: ```c int day = 3; switch(day) { case 1: printf("Monday\n"); break; case 2: printf("Tuesday\n"); break; case 3: printf("Wednesday\n"); break; default: printf("Invalid day\n"); } ``` 使用if-else语句判断成绩等级: ```c int score = 85; if(score >= 90) { printf("A\n"); } else if(score >= 80) { printf("B\n"); } else if(score >= 70) { printf("C\n"); } else { printf("D\n"); } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值