恕我直言,我怀疑你并不会用 Java 枚举(2)

简介: 恕我直言,我怀疑你并不会用 Java 枚举

05、EnumMap


EnumMap 是一个专门针对枚举类型的 Map 接口的实现类,它可以将枚举常量作为键来使用。EnumMap 的效率比 HashMap 还要高,可以直接通过数组下标(枚举的 ordinal 值)访问到元素。


和 EnumSet 不同,EnumMap 不是一个抽象类,所以创建 EnumMap 时可以使用 new 关键字:


EnumMap<PlayerType, String> enumMap = new EnumMap<>(PlayerType.class);


有了 EnumMap 对象后就可以使用 Map 的一些方法了:


image.png


和 HashMap 的使用方法大致相同,来看下面的例子:


EnumMap<PlayerType, String> enumMap = new EnumMap<>(PlayerType.class);
enumMap.put(PlayerType.BASKETBALL,"篮球运动员");
enumMap.put(PlayerType.FOOTBALL,"足球运动员");
enumMap.put(PlayerType.TENNIS,"网球运动员");
System.out.println(enumMap);
System.out.println(enumMap.get(PlayerType.BASKETBALL));
System.out.println(enumMap.containsKey(PlayerType.BASKETBALL));
System.out.println(enumMap.remove(PlayerType.BASKETBALL));
1


程序输出结果如下所示:


{TENNIS=网球运动员, FOOTBALL=足球运动员, BASKETBALL=篮球运动员}

篮球运动员

true

篮球运动员


06、单例


通常情况下,实现一个单例并非易事,不信,来看下面这段代码


public class Singleton {  
    private volatile static Singleton singleton; 
    private Singleton (){}  
    public static Singleton getSingleton() {  
    if (singleton == null) {
        synchronized (Singleton.class) { 
        if (singleton == null) {  
            singleton = new Singleton(); 
        }  
        }  
    }  
    return singleton;  
    }  
}



但枚举的出现,让代码量减少到极致:


public enum EasySingleton{
    INSTANCE;
}


完事了,真的超级短,有没有?枚举默认实现了 Serializable 接口,因此 Java 虚拟机可以保证该类为单例,这与传统的实现方式不大相同。传统方式中,我们必须确保单例在反序列化期间不能创建任何新实例。


07、枚举可与数据库交互


我们可以配合 Mybatis 将数据库字段转换为枚举类型。现在假设有一个数据库字段 check_type 的类型如下:


`check_type` int(1) DEFAULT NULL COMMENT '检查类型(1:未通过、2:通过)',


它对应的枚举类型为 CheckType,代码如下:


public enum CheckType {
  NO_PASS(0, "未通过"), PASS(1, "通过");
  private int key;
  private String text;
  private CheckType(int key, String text) {
  this.key = key;
  this.text = text;
  }
  public int getKey() {
  return key;
  }
  public String getText() {
  return text;
  }
  private static HashMap<Integer,CheckType> map = new HashMap<Integer,CheckType>();
  static {
  for(CheckType d : CheckType.values()){
    map.put(d.key, d);
  }
  }
  public static CheckType parse(Integer index) {
  if(map.containsKey(index)){
    return map.get(index);
  }
  return null;
  }
}


1)CheckType 添加了构造方法,还有两个字段,key 为 int 型,text 为 String 型。


2)CheckType 中有一个public static CheckType parse(Integer index)方法,可将一个 Integer 通过 key 的匹配转化为枚举类型。


那么现在,我们可以在 Mybatis 的配置文件中使用 typeHandler 将数据库字段转化为枚举类型。


<resultMap id="CheckLog" type="com.entity.CheckLog">

 <id property="id" column="id"/>

 <result property="checkType" column="check_type" typeHandler="com.CheckTypeHandler"></result>

</resultMap>

1

2

3

4

其中 checkType 字段对应的类如下:


public class CheckLog implements Serializable {
    private String id;
    private CheckType checkType;
    public String getId() {
        return id;
    }
    public void setId(String id) {
        this.id = id;
    }
    public CheckType getCheckType() {
        return checkType;
    }
    public void setCheckType(CheckType checkType) {
        this.checkType = checkType;
    }
}


CheckTypeHandler 转换器的类源码如下:


public class CheckTypeHandler extends BaseTypeHandler<CheckType> {
  @Override
  public CheckType getNullableResult(ResultSet rs, String index) throws SQLException {
  return CheckType.parse(rs.getInt(index));
  }
  @Override
  public CheckType getNullableResult(ResultSet rs, int index) throws SQLException {
  return CheckType.parse(rs.getInt(index));
  }
  @Override
  public CheckType getNullableResult(CallableStatement cs, int index) throws SQLException {
  return CheckType.parse(cs.getInt(index));
  }
  @Override
  public void setNonNullParameter(PreparedStatement ps, int index, CheckType val, JdbcType arg3) throws SQLException {
  ps.setInt(index, val.getKey());
  }
}

CheckTypeHandler 的核心功能就是调用 CheckType 枚举类的 parse() 方法对数据库字段进行转换。




恕我直言,这篇文章看完后,我觉得小伙伴们肯定会用 Java 枚举了,如果还不会,就过来砍我!


如果觉得文章对你有点帮助,请微信搜索「 沉默王二 」第一时间阅读,回复「并发」更有一份阿里大牛重写的 Java 并发编程实战,从此再也不用担心面试官在这方面的刁难了。


相关文章
|
12天前
|
安全 Java 测试技术
🎉Java零基础:全面解析枚举的强大功能
【10月更文挑战第19天】本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
97 60
|
2月前
|
安全 Java 索引
Java——反射&枚举
本文介绍了Java反射机制及其应用,包括获取Class对象、构造方法、成员变量和成员方法。反射允许在运行时动态操作类和对象,例如创建对象、调用方法和访问字段。文章详细解释了不同方法的使用方式及其注意事项,并展示了如何通过反射获取类的各种信息。此外,还介绍了枚举类型的特点和使用方法,包括枚举的构造方法及其在反射中的特殊处理。
60 9
Java——反射&枚举
|
2月前
|
Java
java小工具util系列4:基础工具代码(Msg、PageResult、Response、常量、枚举)
java小工具util系列4:基础工具代码(Msg、PageResult、Response、常量、枚举)
79 5
|
2月前
|
安全 Java 开发者
Java 枚举(enum)详解
Java 中的枚举(`enum`)是一种特殊的数据类型,用于定义一组固定的常量,提升代码的类型安全性和可读性。枚举使用 `enum` 关键字定义,支持方法和构造函数,具有类型安全、单例、自动序列化等特点,并且可以遍历和用于 `switch` 语句中。实际应用包括状态机、指令集、类型标识等场景。枚举使代码更加清晰易维护。
|
3月前
|
Java
Java枚举使用的基本案例
这篇文章是关于Java枚举的基本使用,通过一个指令下发的代码案例,展示了如何定义枚举、使用枚举以及如何通过枚举实现指令的匹配和处理。
|
3月前
|
Java 开发者
在Java编程中,if-else与switch作为核心的条件控制语句,各有千秋。if-else基于条件分支,适用于复杂逻辑;而switch则擅长处理枚举或固定选项列表,提供简洁高效的解决方案
在Java编程中,if-else与switch作为核心的条件控制语句,各有千秋。if-else基于条件分支,适用于复杂逻辑;而switch则擅长处理枚举或固定选项列表,提供简洁高效的解决方案。本文通过技术综述及示例代码,剖析两者在性能上的差异。if-else具有短路特性,但条件增多时JVM会优化提升性能;switch则利用跳转表机制,在处理大量固定选项时表现出色。通过实验对比可见,switch在重复case值处理上通常更快。尽管如此,选择时还需兼顾代码的可读性和维护性。理解这些细节有助于开发者编写出既高效又优雅的Java代码。
47 2
|
3月前
|
安全 Java 编译器
|
3月前
|
Java
【Java】内部类、枚举、泛型
【Java】内部类、枚举、泛型
|
3月前
|
设计模式 存储 安全
18 Java反射reflect(类加载+获取类对象+通用操作+设计模式+枚举+注解)
18 Java反射reflect(类加载+获取类对象+通用操作+设计模式+枚举+注解)
92 0
|
4月前
|
缓存 开发者 Java
java枚举消除冗余代码问题之需要延迟注册枚举到缓存问题如何解决
java枚举消除冗余代码问题之需要延迟注册枚举到缓存问题如何解决
下一篇
无影云桌面