Enum
public enum Fruit
{
APPLE, BANANA, ORANGE, WATERMELON
}
public class EnumTest
{
public static void main(String[] args)
{
for(Fruit fruit : Fruit.values())
{
test(fruit);
}
}
public static void test(Fruit fruit)
{
switch (fruit)
{
case APPLE:
System.out.println("This is an apple");
break;
case BANANA:
System.out.println("This is a banana");
break;
case ORANGE:
System.out.println("This is an orange");
break;
case WATERMELON:
System.out.println("This is a watermelon");
break;
default:
break;
}
}
}
这里的switch也可以用if-else用来代替, 但是其两者在效率上是有区别的
- 由于switch使用了Binary Tree(二叉树)算法, 而if-else顺序比较(每个条件都要计算一次), 除非if-else的第一个就是true, 大部分情况都是switch的效率要高于if-else.
- switch需要生成最大case常量+1跳转表(jump table, 跳转表是一个数组, 表项i是一个代码段的地址), 所以占用的代码空间要比if-else要大.
- 当case语句多于三个的时候(另一说是大于四个的时候), switch才会创建跳转表, 所以分支较少的情况下, if-else要优于switch.
- 当case后的常量无规律时, 会对case后的常量进行排序.
