Enum的switch用法

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用来代替, 但是其两者在效率上是有区别的

  1. 由于switch使用了Binary Tree(二叉树)算法, 而if-else顺序比较(每个条件都要计算一次), 除非if-else的第一个就是true, 大部分情况都是switch的效率要高于if-else.
  2. switch需要生成最大case常量+1跳转表(jump table, 跳转表是一个数组, 表项i是一个代码段的地址), 所以占用的代码空间要比if-else要大.
  3. 当case语句多于三个的时候(另一说是大于四个的时候), switch才会创建跳转表, 所以分支较少的情况下, if-else要优于switch.
  4. 当case后的常量无规律时, 会对case后的常量进行排序.
posted @ 2016-05-25 18:00  我也姓程  阅读(10615)  评论(0编辑  收藏  举报