JAVA中的枚举

代码示例

理论

枚举的行为多态

java 复制代码
public enum MyLockStrategy {
    SKIP_FAST(){
        @Override
        public boolean tryLock(RLock lock, MyLock prop) throws InterruptedException {
            return lock.tryLock(0, prop.leaseTime(), prop.unit());
        }
    },
    FAIL_AFTER_RETRY_TIMEOUT(){
        @Override
        public boolean tryLock(RLock lock, MyLock prop) throws InterruptedException {
            boolean isLock = lock.tryLock(prop.waitTime(), prop.leaseTime(), prop.unit());
            if (!isLock) {
                throw new BizIllegalException("请求太频繁");
            }
            return true;
        }
    },
    ;

    public abstract boolean tryLock(RLock lock, MyLock prop) throws InterruptedException;
}

为什么可以重写本类的抽象方法

Java 中的枚举本质上是 一种特殊的类(继承自 java.lang.Enum ,每一个枚举常量(比如 SKIP_FASTFAIL_FAST)都是该类的一个 实例(对象)

如果你在枚举中声明了 抽象方法,那么:

每一个枚举常量都必须实现这个抽象方法,因为它们都是枚举类的"子类"或"匿名内部类"的形式存在。

这在 Java 中被称为 枚举的"行为多态"能力

这种设计的好处是什么?

  1. 策略模式(Strategy Pattern)

    每个枚举常量代表一种锁的获取策略,调用时可以根据实际需求选择不同策略。

补充说明:枚举和匿名内部类的关系

虽然 Java 的枚举看起来像是一组常量,但实际上:

  • 每个枚举值其实是一个 匿名内部类的实例
  • 如果枚举类有抽象方法,那这些枚举值就必须实现这些方法;
  • 所以你在枚举中看到的类似类的写法 { ... },其实是创建了一个该枚举类的匿名子类。
相关推荐
Flittly11 小时前
【AgentScope Java新手村系列】(16)从RAG到多路检索
java·spring boot·spring
小兔崽子去哪了11 小时前
Java 生成二维码解决方案
java·后端
人活一口气16 小时前
从JVM调优到MCP协议:Java全栈技术体系深度总结与企业级架构实践
java·spring boot
NE_STOP17 小时前
Vibe Coding -- 完整项目案例实操
java
荣码17 小时前
GraphRAG:普通RAG只能回答"点"的问题,我踩了4个坑才搞懂
java·python
SimonKing17 小时前
Google第三方授权登录
java·后端·程序员
明月光81817 小时前
从一行 @Builder 说起:重新拾起 Java 的 Lombok、注解与 Builder 模式
java
考虑考虑1 天前
Mybatis实现批量插入
java·后端·mybatis
咖啡八杯1 天前
GoF设计模式——中介者模式
java·后端·spring·设计模式
青石路1 天前
记一次多JDK版本问题的排查,一坑套一坑,差点没爬上来
java