黑马程序员技术交流社区

标题: if else为什么比swich效率低 [打印本页]

作者: 张强+    时间: 2011-11-5 00:18
标题: if else为什么比swich效率低
if else为什么比swich效率低
作者: 高美云    时间: 2011-11-5 08:06
首先要看一个问题,if 语句适用范围比较广,只要是 boolean 表达式都可以用 if 判断;而 switch 只能对基本类型进行数值比较。两者的可比性就仅限在两个基本类型比较的范围内。
说到基本类型的数值比较,那当然要有两个数。然后重点来了——
if 语句每一句都是独立的,看下面的语句:
if (a == 1) ...
else if (a == 2) ...
这样 a 要被读入寄存器两次,1 和 2 分别被读入寄存器一次。于是你是否发现其实 a 读两次是有点多余的,在你全部比较完之前只需要一次读入寄存器就行了,其余都是额外开销。但是 if 语句必须每次都把里面的两个数从内存拿出来读到寄存器,它不知道你其实比较的是同一个 a。
于是 switch case 就出来了,把上面的改成 switch case 版本:
switch (a) {
        case 0:
                break;
        case 1:
}
因为特定的规则,他一开始就知道你要比 a,于是 a 一次性读取,相比 if 节约了很多开销。
作者: 吉许    时间: 2011-11-5 08:40
就像上面所说的,if每一次都要去判断条件是否成立,但switch是直接去寻找条件成立的情况去选择.
但switch局限性太多,它后面的括号中只能放int类型的数值,放入byte,short,char类型系统自动会给你放入的自动类型转化成int型.
if语句后面就可以放条件表达式,条件表达式可以返回各种各样的结果.相比switch更加常用.
作者: 常文艺    时间: 2011-11-5 22:00
因为 IF语句功能强,适用度广,肯定占内存稍多,走完这个命令时间也就长一点,原来的JAVA版本SWITCH语句所能处理的数据类型只有byte,short,int,char4种而已,后来又加了字符串还有一个我忘了,好吧我在看看视频找找。
作者: 张翼    时间: 2011-11-7 19:20
从算法上来讲,if和else是一对一的映射,而select是一对多,所以select要面临多次比较,所以select耗费的时间比较多,所以select效率比较低
作者: 梁锡伟    时间: 2011-11-7 20:13
计算机是分多级流水线计算的。。。ifelse始终被分到一条流水线,switch可以被分到多级流水线上




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2