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 的枚举看起来像是一组常量,但实际上:

  • 每个枚举值其实是一个 匿名内部类的实例
  • 如果枚举类有抽象方法,那这些枚举值就必须实现这些方法;
  • 所以你在枚举中看到的类似类的写法 { ... },其实是创建了一个该枚举类的匿名子类。
相关推荐
whltaoin2 小时前
【Spring Boot 注解解析】Bean 生命周期注解深度解析:@PostConstruct 与 @PreDestroy 面试高频考点 + 实战案例
java·spring boot·面试·bean生命周期
蒲公英源码2 小时前
教务管理系统源码
java·mysql
刃神太酷啦2 小时前
力扣校招算法通关:双指针技巧全场景拆解 —— 从数组操作到环检测的高效解题范式
java·c语言·数据结构·c++·算法·leetcode·职场和发展
wu_jing_sheng02 小时前
销售数据分析
开发语言·python
Mos_x2 小时前
计算机组成原理核心知识点梳理
java·后端
墨寒博客栈2 小时前
Linux基础常用命令
java·linux·运维·服务器·前端
回忆是昨天里的海2 小时前
k8s-部署springboot容器化应用
java·容器·kubernetes
haofafa3 小时前
STL之动态数组
开发语言·c++