java枚举的使用, 常量与枚举的区别

public enum Light {
        RED, GREEN, YELLOW;
}


我们只能够表示出红灯、绿灯和黄灯,但是具体的值我们没办法表示出来。

 别急,既然枚举类型提供了构造函数,我们可以通过构造函数和覆写toString方法来实现

首先给Light枚举类型增加构造方法,然后每个枚举类型的值通过构造函数传入对应的参

数, 同时覆写toString方法,在该方法中返回从构造函数中传入的参数,代码如下:

public enum Light {
    RED("红灯"), GREEN("绿灯"), YELLOW("黄灯");

    private String code;

    private Light(String code) {
        this.code = code;
    }


//    @Override
//    public String toString() {
//        return String.valueOf(this.code);
//    }
}

 class EnumTest{
     public static void main(String[] args) {
         System.out.println("============演示枚举类型的遍历:");
         testListEnum();

     }
     static void  testListEnum(){
         Light[] allLight = Light.values();
         for (Light light:allLight) {
             System.out.println("当前灯name:"+light.name());
             System.out.println("当前灯顺序:"+light.ordinal());
             System.out.println("当前灯:"+light);
         }
     }
}



java枚举的使用, 常量与枚举的区别_第1张图片

常量和枚举的区别:

public interface ConstInterfaceA {  
  public static final String CONST_A = "aa";  
  public static final String CONST_C = "ac";  
}



存在问题:

1) 无法限制开发员继承/实现接口.

2) 常量作为参数时,是String,int等弱类型,开发员传入没有在常量接口里定义的值,这个问题无法通过编译器发现.

3) 由于开发员可以直接写常量值, 所以不能用==对比,只能用equals对比,不能优化性能

4) 编译时,是直接把常量的值编译到类的二进制代码里,常量的值在升级中变化后,需要重新编译所有引用常量的类,因为里面存的是旧值.

public class ConstClassA {  
  public static final String CONST_A = "aa";  
  public static final String CONST_C = "ac";  
  
  private ConstClassA() {  
  }  
}



常量类可以设置构造函数为private,从而限制继承,也就没有继续添加常量的问题了.

但是其他问题与常量接口一样无法解决!


枚举类型解决了以上所有问题,主要体现在:

1) 私有构造函数,避免被继承和扩展.

2) 定义方法的参数时,必须用枚举常量类类型,如上面的EnumClassA类型,这样就转变成了强类型,不会出现弱类型引起的问题.

3) 常量值地址唯一,可以用==直接对比,性能会有提高.

4) 编译时,没有把常量值编译到代码里,即使常量的值发生变化也不会影响引用常量的类.


你可能感兴趣的:(枚举,常量与枚举的区别)