在编程中,经常会用到判断,而最常用的就是if..else 和swith,那么两者的区别是什么?
1.if..else
代码块:
if(取值为boolean类型){
//逻辑处理代码块
}else{
//逻辑处理代码块
}
2.swith
代码块:
swith(取值是一个集合){//类型有short int byte String 枚举 char
case A情况://逻辑处理 break;
case A情况://逻辑处理 break;
case A情况://逻辑处理 break;
.....
default :break;
}
那么既然都是一个判断,那么谁的效率更快?
先看一个例子:
我是创建一个数字 分别是按 1 2 3并把最后一个设置成4 判断是1 的时候打印1 2的时候打印2 3的时候打印3 4的时候输出
① 当数量级在10000的时候 swith效率慢与if else
②当数量级10000000时,swith效率快于if...else
事实上,当数据量越大,判断的条件越多,swith的效率越快。
1.执行switch时,会生成一张跳转表,表项数为(最大case值-最小case值+1),跳转表是一个数组,数组是一段连续的内存,jt数组中包含了7个表项(数组索引对应值),每个都是指向对应代码块的指针。在建立索引时,有空间的消耗,但是有了索引能很快的定位到该元素的位置,执行效率快。
2.执行if else的时候事实上是按顺序判断的,一次循环判断,当if嵌套的层数越多,时间复杂度越大,执行效率慢。