通过枚举值调用函数

在做业务的时候,需要根据前端传递的不同枚举参数(比如说0,1)返回对应固定的值。但是这个值需要根据时间又有所变化。我们可以使用if-else去实现对应的逻辑,比如说,当前端传递参数为0是,需要返回当月一号到当前日期的号数。当传递的参数为1时,需要返回当前年份的1月到当前日期的月份。我们可以进行如下处理

public List<Integer> test(Integer type){
    if(type == 0){
        // 对应生成天数的代码
    }else if(type == 1){
        // 对应生成月份的代码
    }
    return ...;
}

 这是枚举值较少的时候,我们这么做也不是不能接受,但是当参数较多时,我们最好还是使用枚举来减少if-else的出现。因此,使用枚举类来处理时,上述代码可以化简为

@Getter
@AllArgsConstructor
@JsonFormat(shape = JsonFormat.Shape.OBJECT)
public enum DateTypeEnum {
    /**
     * 生成 00:00 至 当前时间最近15分钟的时间段集合
     */
    DAY(1, () -> {
        LocalTime current = LocalTime.now().truncatedTo(ChronoUnit.MINUTES);
        LocalTime startTime = LocalTime.MIDNIGHT;
        List<String> intervals = new ArrayList<>();
        while (!startTime.isAfter(current)) {
            intervals.add(startTime.toString());
            startTime = startTime.plusMinutes(15);
        }
        return intervals;
    }),
    /**
     * 生成当前月份1号至当前日期的时间段集合
     */
    MONTH(2, () -> {
        int dayOfMonth = LocalDate.now().getDayOfMonth();
        List<String> days = new ArrayList<>();
        for (int i = 1; i <= dayOfMonth; i++) {
            days.add(String.valueOf(i));
        }
        return days;
    }),
    /**
     * 生成当年1月份至当前月份的时间段集合
     */
    YEAR(3, () -> {
        LocalDate current = LocalDate.now();
        int currentMonth = current.getMonthValue();
        List<String> dateList = new ArrayList<>();
        for (int i = 1; i <= currentMonth; i++) {
            dateList.add(Month.of(i).getDisplayName(TextStyle.FULL, Locale.CHINA));
        }
        return dateList;
    });
    private Integer code;
    private Supplier<List> desc;
    public static final List<DateTypeEnum> LIST =
            Arrays.stream(values()).toList();
    public static final Map<Integer, DateTypeEnum> MAP = LIST.stream()
            .collect(Collectors.toMap(DateTypeEnum::getCode, f -> f));

    public static DateTypeEnum ofCode(Integer code) {
        return MAP.get(code);
    }
}

<think>嗯,用户的问题是关于如何在Java中根据枚举获取对应的枚举名称。我需要先仔细理解他的需求。他可能有一个枚举类型,里面有不同的枚举常量,每个常量可能有对应的,比如数字或者字符串,他想通过这个来找到对应的枚举常量的名称。 首先,我需要回想一下Java枚举的基本知识。枚举Java中是一种特殊的类,每个枚举常量都是该类的实例。通常,枚举可以有字段、构造函数和方法。比如,用户可能定义了一个枚举,每个枚举常量有一个关联的,比如状态码或者数据库中的代码,然后想通过这个来获取枚举的名称。 接下来,用户需要的是根据获取名称的方法。常用的方法有哪些呢?我记得可以通过遍历枚举的values()方法,逐个比较,找到匹配的枚举常量,然后调用name()方法或者自定义的获取名称的方法。另外,可能还可以用Java 8的流式API来简化这个过程,或者使用反射,但反射可能比较复杂且不安全,不太推荐。 现在,我需要参考用户提供的引用内容。引用[1]提到使用values()和name()方法,引用[2]也提到了values()方法,引用[3]提到流式编程处理枚举,引用[4]讲的是反射获取枚举参数。所以,用户提供的资料中有几种方法:遍历、流式处理、反射。但反射可能不是最佳实践,应该优先考虑前两种。 然后,我应该考虑如何组织回答。首先,定义一个示例枚举,比如StatusEnum,包含code和name属性,并给出构造函数和getter方法。然后,分步骤说明不同的方法: 1. 基础遍历法:使用values()遍历,比较,返回对应的枚举实例,再获取name。 2. 流式处理法:使用Stream和filter,结合findFirst,处理可能的空情况。 3. 反射方法:虽然用户提到反射,但需要指出其风险,不推荐使用。 需要提供示例代码,并确保代码语法正确。例如,在遍历方法中,可能需要处理找不到的情况,返回null或抛出异常。流式处理可以用Optional来处理可能为空的情况。 另外,用户的问题可能涉及到如何定义枚举,如何添加自定义字段,所以示例代码中的枚举定义部分要完整,展示字段和构造方法。 可能还需要注意事项,比如枚举是否唯一,如何处理重复,或者性能考虑,比如使用静态Map来缓存,提高查找效率。但根据用户提供的引用,可能暂时不需要涉及更复杂的优化,保持回答简洁。 最后,生成相关问题,比如如何反向查找,如何优化性能,如何处理重复,或者如何在其他框架中使用枚举转换,比如Spring或MyBatis。 检查是否所有代码都正确,比如流式处理中的orElse(null),确保Optional正确使用。反射部分的代码可能较复杂,需要正确获取方法并调用,但用户引用[4]中的代码示例可能有帮助。 总结步骤:定义枚举,展示三种方法,给出代码示例,注意事项,相关问题。</think>### Java根据枚举获取枚举名称的实现方法 在Java中根据枚举获取对应的枚举名称,可通过以下三种方法实现。这里以包含`code`和`name`属性的枚举类型为例进行说明。 #### 1. 基础遍历法 通过遍历枚举的所有并比对目标,最终返回匹配的枚举常量名称。 ```java public enum StatusEnum { SUCCESS(200, "成功"), ERROR(500, "错误"); private final int code; private final String name; StatusEnum(int code, String name) { this.code = code; this.name = name; } public int getCode() { return code; } public String getName() { return name; } public static String getNameByCode(int targetCode) { for (StatusEnum status : StatusEnum.values()) { if (status.getCode() == targetCode) { return status.name(); // 返回枚举常量名称 } } return null; // 未找到时返回null } } // 使用示例 String enumName = StatusEnum.getNameByCode(200); // 返回"SUCCESS" ``` #### 2. 流式编程法(Java 8+) 利用Stream API实现更简洁的查找逻辑: ```java public static String getNameByCode(int targetCode) { return Arrays.stream(StatusEnum.values()) .filter(status -> status.getCode() == targetCode) .findFirst() .map(Enum::name) .orElse(null); // 未找到时返回null } ``` #### 3. 反射方法(不推荐) 通过反射获取枚举属性,适用于动态场景,但存在性能和安全风险: ```java public static String getNameByCodeViaReflection(int targetCode) throws Exception { Class<StatusEnum> enumClass = StatusEnum.class; Method getCodeMethod = enumClass.getMethod("getCode"); for (Object enumConstant : enumClass.getEnumConstants()) { int code = (int) getCodeMethod.invoke(enumConstant); if (code == targetCode) { return ((Enum<?>) enumConstant).name(); } } return null; } ``` #### 注意事项 - **唯一性**:需确保枚举的唯一性,否则可能返回第一个匹配项 - **性能优化**:频繁调用时可使用静态Map缓存,例如: ```java private static final Map<Integer, String> CODE_TO_NAME = Arrays.stream(StatusEnum.values()) .collect(Collectors.toMap(StatusEnum::getCode, StatusEnum::name)); ``` - **空处理**:建议使用`Optional`或抛出明确异常替代返回`null`
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zmbwcx2003

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值