hello,大家好,这里是可傥。明天,咱们来聊一下枚举enmu。枚举作为JDK1.5引入了新的类型,置信大家都不生疏,那么,具体有哪些用法呢,上面开展讲讲:

一、定义常量

在1.5之前,咱们定义一个常量,通常用final关键字。而有了枚举之后,咱们能够将一类常量定义在枚举类中,这样不便查找,代码逻辑也更清晰。如:

public enum ErrorCodeEnum {    CODE_ACCOUNT_ERROR, CODE_TOKEN_ERROR,     CODE_PARAM_EMPTY, CODE_PARAM_ERROR, CODE_SUCCESS}

这样找一类常量就会十分不便。

二、 枚举类的应用

这是比拟罕用的办法,在枚举类中增加本人的一些办法,也能够笼罩枚举的办法。这时,留神,先定义枚举,而后最初的枚举用分号和上面隔开。代码如下:

/** * @author ketang * 错误代码枚举 */public enum ErrorCodeEnum {    CODE_SUCCESS("1", "success"),    CODE_FAILED("0", "failed"),    CODE_ACCOUNT_ERROR("1001", "账号谬误"),    CODE_TOKEN_ERROR("1002", "token已过期"),    CODE_PARAM_EMPTY("1003", "必选参数为空"),    CODE_PARAM_ERROR("1004", "参数格局谬误"),    FILE_NOT_EXIST("1101", "文件不存在"),    //留神分号    SYSTEM_UNKNOWN_ERROR("-1", "零碎忙碌,请稍后再试....");    //成员变量    private String code;    private String desc;    //构造方法    ErrorCodeEnum(String code, String desc) {        this.code = code;        this.desc = desc;    }    //一般办法    /**     *     * @param code     * @return     */    public static ErrorCodeEnum getByCode(String code) {        for (ErrorCodeEnum errorCodeEnum : ErrorCodeEnum.values()) {            if(StringUtils.equals(errorCodeEnum.code, code)) {                return errorCodeEnum;            }        }        return null;    }    //getter办法    /**     * Getter method for property <tt>code</tt>.     *     * @return property value of code     */    public String getCode() {        return this.code;    }    /**     * Getter method for property <tt>desc</tt>.     *     * @return property value of desc     */    public String getDesc() {        return desc;    }    //笼罩办法    @Override    public String toString() {        return "ErrorCodeEnum{" + "code='" + code + '\'' + ", desc='" + desc + '\'' + '}';    }}

将枚举类以这种形式开展,逻辑将会更加清晰。

三、枚举类实现接口

所有的枚举都继承自java.lang.Enum类。因为Java 不反对多继承,所以枚举对象不能再继承其余类,然而却能够去实现接口。如以下代码:

public interface ErrorBase{     void print(); } public enum ErrorCodeEnum implements ErrorBase{    CODE_SUCCESS("1", "success"),    CODE_FAILED("0", "failed"),    CODE_ACCOUNT_ERROR("1001", "账号谬误"),    CODE_TOKEN_ERROR("1002", "token已过期"),    CODE_PARAM_EMPTY("1003", "必选参数为空"),    CODE_PARAM_ERROR("1004", "参数格局谬误"),    FILE_NOT_EXIST("1101", "文件不存在"),    //留神分号    SYSTEM_UNKNOWN_ERROR("-1", "零碎忙碌,请稍后再试....");    //成员变量    private String code;    private String desc;    //构造方法    ErrorCodeEnum(String code, String desc) {        this.code = code;        this.desc = desc;    }    //getter办法    /**     * Getter method for property <tt>code</tt>.     *     * @return property value of code     */    public String getCode() {        return this.code;    }    /**     * Getter method for property <tt>desc</tt>.     *     * @return property value of desc     */    public String getDesc() {        return desc;    }        //接口办法     @Override     public void print() {         System.out.println(this.code+":"+this.desc);     } }

这是实现接口,还有一种形式则是在接口中组织枚举。

四、接口组织枚举

在接口中定义和该接口相干的枚举汇合
如以下代码:

public interface ErrorBase{     enum BaseErrorCode implements Food{         CODE_SUCCESS,CODE_FAILED    }     enum CommonErrorCode implements Food{         CODE_ACCOUNT_ERROR, CODE_TOKEN_ERROR,        CODE_PARAM_EMPTY    } }

枚举的次要应用就讲到这里,在switch case判断中中,也能够将枚举当做条件退出。tips:switch中的条件也容许枚举哦。
枚举明天咱们就聊到这,这里是可傥,将会分享本人的所学以及所得,欢送大家一起交换。CSDN地址为:https://blog.csdn.net/kaneand...