Java 枚举的基本使用方法及实际使用场景

2025-06-06 03:50

本文主要是介绍Java 枚举的基本使用方法及实际使用场景,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《Java枚举的基本使用方法及实际使用场景》枚举是Java中一种特殊的类,用于定义一组固定的常量,枚举类型提供了更好的类型安全性和可读性,适用于需要定义一组有限且固定的值的场景,本文给大家介绍Jav...

一、什么是枚举?

枚举(enum)是 Java 中一种特殊的类,用于定义一组固定的常量。枚举类型提供了更好的类型安全性和可读性,适用于需要定义一组有限且固定的值的场景。枚举常量是 public static final 的,可以直接通过枚举类名访问。

枚举的主要特点:

类型安全:限制了变量的取值范围,避免了无效值的传入。
代码简洁:枚举可以代替大量的常量定义,使代码更简洁。
易于维护:枚举将相关的常量集中在一起,便于维护扩展。

二、枚举的基本使用方法

定义枚举

通过 enum 关键字定义,语法如下:

public enum 枚举名 {
    常量1,
    常量2,
    常量3;
}

例如:星期

public enum Week {
    MONDAY, TUESDAY, WEDNESDAY, THURSDAY, FRIDAY, SATURDAY, SUNDAY;
}

另外,枚举还可以定义属性和方法,甚至可以定义构造函数。例如:

public enum Status {
    ACTIVE(1, "激活"),
    INACTIVE(2, "未激活");
    private int code;
    private String description;
    // 枚举的构造函数
    Status(int code, String description) {
        this.code = code;
        this.description = description;
    }
    public int getCode() {
        return code;
    }
    public String getDescription() {
        return description;
    }
}

枚举类继承自 java.lang.Enum ,有一些自带的方法:比如 name()ordinal()javascriptvalues()valueOf(String)。不过我一般比较少使用这些方法,实际中我会按下面使用枚举。

三、实际使用场景

代替常量

枚举可以用来替代传统的常量定义(如 public static final int),提供更好的可读性和类型安全性。

状态机

表示有限的状态,比如状态、类型等业务数据。例如:

public enum Status
{
    OK("0", "正常"), DISABLE("1", "停用"), DELETED("2", "删除");
    private final String code;
    private final String info;
    Status(String copythonde, String info)
    {
        this.code = code;
        this.info = info;
    }
    public String getCode()
    {
        return code;
    }
    public String getInfo()
    {
        return info;
    }
	public static String getInfoByCode(String code){
        for (Status value : values()) {
            if (code.equals(value.code))return value.info;
        }
        return null;
    }
    public static List<String> getCodeList(){
        List<String> codeList = new ArrayList<>();
        for (Status value : Status.values()) {
            codeList.add(value.getCode());
        }
        return codeList;
    }
}

四、更多用法

1.实现接口

枚举可以实现接口,从而扩展功能。
像上文中自定义方法 getCode()getInfo()getInfoByCode()getCodeList() 都是单独为这个枚举创建的。

我们可以定义一个通用的接口。

public interface KeyValueEnum<K, V> {
    K getKey();
    V getValue();
}

然后枚举类可以修改为:

public enum Status implements KeyValueEnum<String, String> {
    OK("0", "正常"), DISABLE("1", "停用"), DELETED("2", "删除");
    private String key;
    private String value;
    Status(String key, String value) {
        this.key = key;
        this.value = value;
    }
    @Override
    public String getKey() {
        return key;
    }
    @Override
    public String getValue() {
        return value;
    }
}

getInfoByCode()getCodeList()可以创建为工具类。

import java.util.ArrayList;
import java.util.List;
public class EnumUtils {
    /**
     * 根据 key 获取枚举的 value
     *
     * @param enumClass 枚举类
     * @param key       key
     * @param <K>       key 类型
     * @param <V>       value 类型
     * @param <E>       枚举类型
     * @return 对应的 value,如果未找到则返回 null
     */
    public static <K, V, E extends Enum<E> & KeyValueEnum<K, V>> V getValueByKey(Class<E> enumClass, K key) {
        for (E value : enumClass.getEnumConstants()) {
            if (value.getKey().equals(key)) {
                return value.getValue();
            }
        }
        return null;
    }
    /**
     * 根据 value 获取枚举的 key
     *
     * @param enumClass 枚举类
     * @param value     value
     * @param <K>       key 类型
     * @param <V>       value 类型
     * @param <E>       枚举类型
     * @return 对应的 key,如果未找到则返回 null
     */
    public static <K, V, E extends Enum<E> & KeyValueEnum<K, V>> K getKeyByValue(Class<E> enumClass, V value) {
        for (E e : enumClass.getEnumConstants()) {
            if (e.getValue().equals(value)) {
                return e.getKey();
            }
        }
        return null;
    }
    /**
     * 获取枚举类的所有 key 值
     *
     * @param enumClass 枚举类
     * @param <K>       key 类型
     * @param <V>       value 类型
     * @param <E>       枚举类型
     * @return 包含所有 key 的列表
     */
    public static <K, V, E extends Enum<E> & KeyValueEnumIqSpBQlse<K, V>> List<K> getKeyList(Class<E> enumClass) {
        List<K> keyList = new ArrayList<>();
        for (E value : enumClass.getEnumConstants()) {
          http://www.chinasem.cn  keyList.add(value.getKey());
        }
        return keyList;
    }
}

使用工具类:

public class Main {
    public static void main(String[] args) {
        // 获取 Status 枚举的所有 key 值
        List<String> keyList = EnumUtils.getKeyList(Status.class);
        System.out.println(keyList); // 输出 ["0", "1", "2"]
		// 根据 key 获取 value
        String statusValue = EnumUtils.getValueByKey(Status.class, 1);
        System.out.println(statusValue); // 输出 "停用"
        // 根据 value 获取 key
        Integer statusKey = EnumUtils.getKeyByValue(Status.class, "正常");
        System.out.println(statusKey); // 输出 0
    }
}

2.单例模式

枚举可以用来实现单例模式,确保一个类只有一个实例。

public enum Singleton {
    INSTANCE;
    public void example() {
        System.out.println("枚举实现单例模式");
    }
}

那么,为什么枚举可以实现单例模式呢?

枚举(enum)作为单例模式是一种非常优雅且安全的实现方式。主要是因为:

  • 枚举常量在 JVM 中是唯一的,每个枚举常量都是枚举类的一个实例。
  • 枚举常量在类加载时被初始化,且只会初始化一次。
  • 枚举的构造函数是私有的,无法通过反射或手动调用构造函数创建新的实例。
  • 枚举的序列化和反序列化由 JVM 保证,反序列化时不会创建新的实例。

3.策略模式

枚举可以用来实现简单的策略模式,每个枚举常量可以定义自己的行为。
比如:进行一些运算。

public enum Operation {
    ADD {
        public int apply(int a, int b) {
            return a + b;
  python      }
    },
    SUBTRACT {
        public int apply(int a, int b) {
            return a - b;
        }
    };
    public abstract int apply(int a, int b);
}

总结

枚举的使用可以使代码的可读性更高,更易于维护,并且可以进行一些特定的扩展。但是要注意枚举的使用场景,如果常量特别多或者会频繁变化的值,就不适合使用枚举。

到此这篇关于Java 枚举的基本使用方法及实际使用场景的文章就介绍到这了,更多相关Java 枚举用法内容请搜索China编程(www.chinasem.cn)以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程China编程(www.chinasem.cn)!

这篇关于Java 枚举的基本使用方法及实际使用场景的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1154933

相关文章

mybatis-plus QueryWrapper中or,and的使用及说明

《mybatis-plusQueryWrapper中or,and的使用及说明》使用MyBatisPlusQueryWrapper时,因同时添加角色权限固定条件和多字段模糊查询导致数据异常展示,排查发... 目录QueryWrapper中or,and使用列表中还要同时模糊查询多个字段经过排查这就导致只要whe

Spring Boot3.0新特性全面解析与应用实战

《SpringBoot3.0新特性全面解析与应用实战》SpringBoot3.0作为Spring生态系统的一个重要里程碑,带来了众多令人兴奋的新特性和改进,本文将深入解析SpringBoot3.0的... 目录核心变化概览Java版本要求提升迁移至Jakarta EE重要新特性详解1. Native Ima

Java中的xxl-job调度器线程池工作机制

《Java中的xxl-job调度器线程池工作机制》xxl-job通过快慢线程池分离短时与长时任务,动态降级超时任务至慢池,结合异步触发和资源隔离机制,提升高频调度的性能与稳定性,支撑高并发场景下的可靠... 目录⚙️ 一、调度器线程池的核心设计 二、线程池的工作流程 三、线程池配置参数与优化 四、总结:线程

Spring Boot 与微服务入门实战详细总结

《SpringBoot与微服务入门实战详细总结》本文讲解SpringBoot框架的核心特性如快速构建、自动配置、零XML与微服务架构的定义、演进及优缺点,涵盖开发环境准备和HelloWorld实战... 目录一、Spring Boot 核心概述二、微服务架构详解1. 微服务的定义与演进2. 微服务的优缺点三

Olingo分析和实践之ODataImpl详细分析(重要方法详解)

《Olingo分析和实践之ODataImpl详细分析(重要方法详解)》ODataImpl.java是ApacheOlingoOData框架的核心工厂类,负责创建序列化器、反序列化器和处理器等组件,... 目录概述主要职责类结构与继承关系核心功能分析1. 序列化器管理2. 反序列化器管理3. 处理器管理重要方

我们来说说Java LockSupport 的 park 和 unpark

《我们来说说JavaLockSupport的park和unpark》LockSupport是JDK底层线程阻塞工具,通过park/unpark实现线程阻塞与唤醒,避免死锁,与Object的w... 目录一、LockSupport1.1、LockSupport函数列表1.2、基本使用先 park 再 unpa

SpringBoot集成MyBatis实现SQL拦截器的实战指南

《SpringBoot集成MyBatis实现SQL拦截器的实战指南》这篇文章主要为大家详细介绍了SpringBoot集成MyBatis实现SQL拦截器的相关知识,文中的示例代码讲解详细,有需要的小伙伴... 目录一、为什么需要SQL拦截器?二、MyBATis拦截器基础2.1 核心接口:Interceptor

Python错误AttributeError: 'NoneType' object has no attribute问题的彻底解决方法

《Python错误AttributeError:NoneTypeobjecthasnoattribute问题的彻底解决方法》在Python项目开发和调试过程中,经常会碰到这样一个异常信息... 目录问题背景与概述错误解读:AttributeError: 'NoneType' object has no at

Python使用openpyxl读取Excel的操作详解

《Python使用openpyxl读取Excel的操作详解》本文介绍了使用Python的openpyxl库进行Excel文件的创建、读写、数据操作、工作簿与工作表管理,包括创建工作簿、加载工作簿、操作... 目录1 概述1.1 图示1.2 安装第三方库2 工作簿 workbook2.1 创建:Workboo

SpringBoot集成EasyPoi实现Excel模板导出成PDF文件

《SpringBoot集成EasyPoi实现Excel模板导出成PDF文件》在日常工作中,我们经常需要将数据导出成Excel表格或PDF文件,本文将介绍如何在SpringBoot项目中集成EasyPo... 目录前言摘要简介源代码解析应用场景案例优缺点分析类代码方法介绍测试用例小结前言在日常工作中,我们经