java-enum枚举类

枚举类 默认 隐式继承java.lang.Enum抽象类

java.lang.Enum是所有java语言枚举类型的公共基类。
*关于枚举的更多信息,包括对
*由编译器合成的隐式声明
注意,当使用枚举类型作为集合的类型时
*或作为Map中键的类型,专业化和高效化
可以用
{@linkplain java.util.EnumSet set}
and {@linkplain java.util.EnumMap map}

常用方法

构造器

唯一的构造器。程序员不能调用这个构造函数。供编译器响应的代码使用枚举类型声明。

name-这个枚举常量的名称,它是标识符用来声明它。

ordinal-这个枚举常数的序号(其位置)在EnUM声明中,其中赋值初始常数零的序数)。

 protected Enum(String name, int ordinal) {
        this.name = name;
        this.ordinal = ordinal;
    }

返回这个枚举常数的序号(其位置)在其枚举声明中,其中初始常数被赋值零的序数)。
大多数程序员对这种方法毫无用处。它是设计用于复杂的基于枚举的数据结构,例如
* {@链接java使用java. EnumSet }和{@链接java util EnumMap }
该方法获取的是枚举变量在枚举类中声明的顺序,下标从0开始,如日期中的MONDAY在第一个位置,那么MONDAY的ordinal值就是0,如果MONDAY的声明位置发生变化,那么ordinal方法获取到的值也随之变化,注意在大多数情况下我们都不应该首先使用该方法,毕竟它总是变幻莫测的。compareTo(E o)方法则是比较枚举的大小,注意其内部实现是根据每个枚举的ordinal值大小进行比较的。name()方法与toString()几乎是等同的,都是输出变量的字符串形式。至于valueOf(Class enumType, String name)方法则是根据枚举类的Class对象和枚举名称获取枚举常量,注意该方法是静态的,后面在枚举单例时,

  public final int ordinal() {
        return ordinal;
    }

将此枚举与指定的对象进行比较。返回负整数、零或正整数,因为此对象较少。
*大于、等于或大于指定的对象。

EnUM常量只能与其他相同枚举类型常量相比较。自然秩序的实现方法是声明常量的顺序。

 public final int compareTo(E o) {
        Enum<?> other = (Enum<?>)o;
        Enum<E> self = this;
        if (self.getClass() != other.getClass() && // optimization
            self.getDeclaringClass() != other.getDeclaringClass())
            throw new ClassCastException();
        return self.ordinal - other.ordinal;
    }

用指定的枚举返回指定枚举类型的枚举常数指定名称。名称必须与使用的标识符完全匹配。
在此类型中声明枚举常量。(多余空白)字符是不允许的。
注意,对于特定的枚举类型{@代码t},隐式声明{@代码公共静态t值(字符串)}
可以使用该枚举的方法代替该方法映射
从名称到相应的枚举常量。所有的枚举类型的常量可以通过调用
*隐式 {@code public static T[] values()}方法获得。

public static


values()方法是由编译器插入到枚举类中的static方法

其内部使用位向量,存储结构很简洁,节省空间,大部分操作都是按位运算,直接操作二进制数据,因此效率极高

**序列化**
枚举序列化是由jvm保证的,每一个枚举类型和定义的枚举变量在JVM中都是唯一的,在枚举类型的序列化和反序列化上,Java做了特殊的规定:在序列化时Java仅仅是将枚举对象的name属性输出到结果中,反序列化的时候则是通过java.lang.Enum的valueOf方法来根据名字查找枚举对象。同时,编译器是不允许任何对这种序列化机制的定制的并禁用了writeObject、readObject、readObjectNoData、writeReplace和readResolve等方法,从而保证了枚举实例的唯一性,这里我们不妨再次看看Enum类的valueOf方法


**单例**

public enum SingletonEnum {
INSTANCE;
private String name;
public String getName(){
return name;
}
public void setName(String name){
this.name = name;
}
}
“`

总结

可以创建一个enum类,把它看做一个普通的类。除了它不能继承其他类了。(java是单继承,它已经继承了Enum),可以添加其他方法,覆盖它本身的方法

switch()参数可以使用enum

values()方法是编译器插入到enum定义中的static方法,所以,当你将enum实例向上转型为父类Enum是,values()就不可访问了。
解决办法:在Class中有一个getEnumConstants()方法,所以即便Enum接口中没有values()方法,我们仍然可以通过Class对象取得所有的enum实例

编译器生成的values()方法
这里写图片描述

无法从enum继承子类,如果需要扩展enum中的元素,在一个接口的内部,创建实现该接口的枚举,以此将元素进行分组。达到将枚举元素进行分组。

enum允许程序员为eunm实例编写方法。所以可以为每个enum实例赋予各自不同的行为。

参考资料

https://blog.csdn.net/javazejian/article/details/71333103

猜你喜欢

转载自blog.csdn.net/qq_16038125/article/details/80729753