switch case和if else效率区别

switch…case写法:

switch (表达式){ 
case 值1 : 语句1 break; 
case 值2 : 语句2 break; 
... 
default : 语句n break; 
}

if…else写法:

if(boolean){
 
}else if(boolean){
 
}else if(boolean){
 
}else{
 
}

由此看来,switch有点以空间换时间的意思,而事实上也的确如此。

  • 当分支较多时,当时用switch的效率是很高的。因为switch是随机访问的,就是确定了选择值之后直接跳转到那个特定的分支,但是if。。else是遍历所有的可能值,直到找到符合条件的分支。
  • 由汇编代码可知道,switch…case占用较多的代码空间,因为它要生成跳表,特别是当case常量分布范围很大但实际有效值又比较少的情况,switch…case的空间利用率将变得很低。
  • switch…case只能处理case为常量的情况,对非常量的情况是无能为力的。例如 if (a > 1 && a < 100),是无法使用switch…case来处理的。所以,switch只能是在常量选择分支时比ifelse效率高,但是ifelse能应用于更多的场合,ifelse比较灵活。
  • 在已知某几种分支出现概率较高的情况下,使用if else,将高概率分支前几位,由于if else是遍历所有值,所以使用这种方式的效率要比switch case高
  • 分支出现概率相同或未知的情况下,若分支数小于5, if else的效率比switch case高,反之分支数大于5,switch case效率比if else高。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值