java枚举值的使用

1.java枚举值解决类型安全的问题,范围问题,能获取一组值的集合,这些是public static final常量不能做到的

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

3.switch()参数可以使用enum了

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

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

6.使用EnumSet代替标志。enum要求其成员都是唯一的,但是enum中不能删除添加元素。

7.EnumMap的key是enum,value是任何其他Object对象。

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

9.使用enum的职责链(Chain of Responsibility) .这个关系到设计模式的职责链模式。以多种不同的方法来解决一个问题。然后将他们链接在一起。当一个请求到来时,遍历这个链,直到链中的某个解决方案能够处理该请求。

10.使用enum的状态机

11.使用enum多路分发

这里举例说明

package com.fruitking.cms.autoflow;

public class CmsConstants {

public enum TaskDefineState {

ON("1","启动"), OFF("0","关闭");

private String flag;
private String name;

private TaskDefineState(String flag,String name){
this.flag = flag;
this.name = name;
}

public String getFlag() {
return flag;
}
public void setFlag(String flag) {
this.flag = flag;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
};

public enum TaskExecuteState {

ON("1","未执行"), OFF("0","已执行");

private String flag;
private String name;

private TaskExecuteState(String flag,String name){
this.flag = flag;
this.name = name;
}
public String getFlag() {
return flag;
}
public void setFlag(String flag) {
this.flag = flag;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
};


}


package com.fruitking.cms.autoflow;

import java.util.EnumMap;
import java.util.EnumSet;

import com.fruitking.cms.autoflow.CmsConstants.TaskDefineState;
import com.fruitking.cms.autoflow.CmsConstants.TaskExecuteState;

public class TestEnum {
//测试函数
public static void main(String[] args) {
//直接变量enum
for (TaskDefineState s : TaskDefineState.values())
System.out.println(s.name());
//switch与enum的结合使用
TaskDefineState switchStated = TaskDefineState.OFF;
switch (switchStated) {
case OFF:
System.out.println("select OFF");
break;
case ON:
System.out.println("select ON");
break;
}
//EnumSet的使用
EnumSet<TaskDefineState> stateSetd = EnumSet.allOf(TaskDefineState.class);
for (TaskDefineState s : stateSetd) {
System.out.println(s);
}
//EnumMap的使用
EnumMap stateMapd = new EnumMap(
TaskDefineState.class);
stateMapd.put(TaskDefineState.ON, "is On");
stateMapd.put(TaskDefineState.OFF, "is off");
for (TaskDefineState s : TaskDefineState.values()) {
System.out.println(s.name() + ":" + stateMapd.get(s));
}

System.out.println("---------------------------------------------------");
//直接变量enum
for (TaskExecuteState s : TaskExecuteState.values())
System.out.println(s.getFlag()+":"+s.getName());
//switch与enum的结合使用
TaskExecuteState switchStatee = TaskExecuteState.OFF;
switch (switchStatee) {
case OFF:
System.out.println("select OFF");
break;
case ON:
System.out.println("select ON");
break;
}
//EnumSet的使用
EnumSet<TaskExecuteState> stateSete = EnumSet.allOf(TaskExecuteState.class);
for (TaskExecuteState s : stateSete) {
System.out.println(s);
}
//EnumMap的使用
EnumMap stateMape = new EnumMap(
TaskExecuteState.class);
stateMape.put(TaskExecuteState.ON, "is On");
stateMape.put(TaskExecuteState.OFF, "is off");
for (TaskExecuteState s : TaskExecuteState.values()) {
System.out.println(s.name() + ":" + stateMape.get(s));
}
}
}
### 如何在Java中将枚举类型映射到实体类 为了实现枚举类型的映射,可以采用多种方式来确保枚举能够被正确地转换成实体类中的属性。一种常见的方式是在枚举定义内部提供额外的方法以便于这种转换。 #### 使用自定义方法进行转换 通过为枚举添加静态工厂方法以及实例化构造函数,可以从字符串或其他形式的数据源轻松创建对应的枚举实例。这有助于当从数据库读取数据并希望将其映射回特定的枚举成员时非常有用[^3]。 ```java public enum Status { ACTIVE(1, "Active"), INACTIVE(0, "Inactive"); private final int code; private final String description; Status(int code, String description) { this.code = code; this.description = description; } public static Status fromCode(Integer code) { for (Status status : values()) { if (status.getCode().equals(code)) { return status; } } throw new IllegalArgumentException("Unknown code: " + code); } public Integer getCode() {return code;} public String getDescription() {return description;} } ``` #### 实体类与枚举关联 为了让实体类能更好地处理这些枚举类型,在实体类的设计上应该考虑加入相应的逻辑以支持双向映射——即不仅允许由枚举转实体,也应支持反向操作。下面是一个简单的例子展示了如何做到这一点: ```java import javax.persistence.Entity; import javax.persistence.Id; @Entity public class User { @Id private Long id; // 枚举字段 private Status status; // Getter 和 Setter 方法 public void setStatus(Status status){ this.status=status; } public Status getStatus(){ return this.status; } } // 当从前端接收JSON请求时,如果使用Jackson库,则可以通过@JsonFormat注解指定序列化的格式。 // 如果遇到类型不匹配的问题,可能是因为缺少了必要的注解如@JsonValue或@JsonCreator等[^2]. ``` 对于`@XmlElement`的应用场景而言,它主要用于JAXB(Java Architecture for XML Binding)环境中,用来指示某个字段应当作为XML文档的一部分输出。因此,若要使枚举成为XML的一部分,可以在其声明处加上此注解[^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值