通用java枚举类转List-Map集合

java的枚举类功能是很强大的,在平时开发中也用的比较多,有时候可能会有将枚举类转成List集合这种需求,如果能确定枚举类中的字段固定可以使用实体类接收,如果不固定的话,很多时候只能用Map来接收了。

这里实现一下java枚举类转List-Map集合:

	/**
     * java枚举类转List<Map>集合
     * 
     * @param clazz
     * @return null-该class不是枚举类型  []-该枚举类型没有自定义字段  list-获取该枚举类型的List<Map>返回结果
     */
    public static List<Map<String, Object>> enumToListMap(Class<?> clazz) {
        List<Map<String, Object>> resultList = null;
        // 判断是否是枚举类型
        if ("java.lang.Enum".equals(clazz.getSuperclass().getCanonicalName())) {
            resultList = new ArrayList<>();
            // 获取所有public方法
            Method[] methods = clazz.getMethods();
            List<Field> fieldList = new ArrayList<>();
            for (int i = 0; i < methods.length; i++) {
                String methodName = methods[i].getName();
                if (methodName.startsWith("get") && !"getDeclaringClass".equals(methodName)
                    && !"getClass".equals(methodName)) { // 找到枚举类中的以get开头的(并且不是父类已定义的方法)所有方法
                    Field field = null;
                    try {
                        field = clazz.getDeclaredField(StringUtils.uncapitalize(methodName.substring(3))); // 通过方法名获取自定义字段
                    } catch (NoSuchFieldException | SecurityException e) {
                        e.printStackTrace();
                    }
                    if (field != null) { // 如果不为空则添加到fieldList集合中
                        fieldList.add(field);
                    }
                }
            }
            if (!fieldList.isEmpty()) { // 判断fieldList集合是否为空
                Map<String, Object> map = null;
                Enum<?>[] enums = (Enum[])clazz.getEnumConstants(); // 获取所有枚举
                for (int i = 0; i < enums.length; i++) {
                    map = new HashMap<>();
                    for (int l = 0, len = fieldList.size(); l < len; l++) {
                        Field field = fieldList.get(l);
                        field.setAccessible(true);
                        try {
                            map.put(field.getName(), field.get(enums[i])); // 向map集合添加字段名称 和 字段值
                        } catch (IllegalArgumentException | IllegalAccessException e) {
                            e.printStackTrace();
                        }
                    }
                    resultList.add(map);// 将Map添加到集合中
                }
            }
        }
        return resultList;
    }

新建几个枚举类和普通类测试一下:

public class TestEnum0 {

}
public enum TestEnum1 {
    TestEnum1;
}
public enum TestEnum2 {
    TestEnum2("TestEnum2");

    private String name;

    TestEnum2(String name) {
        this.name = name;
    }

    public String getName() {
        return name;
    }
}
public enum TestEnum3 {
    TestEnum3(1, "TestEnum3", "测试枚举类");

    private int id;

    private String message;

    private String desc;

    TestEnum3(int id, String message, String desc) {
        this.id = id;
        this.message = message;
        this.desc = desc;
    }

    public int getId() {
        return id;
    }

    public String getMessage() {
        return message;
    }

    public String getDesc() {
        return desc;
    }
}

编写测试方法:

	@Test
    public void enumToListMapTest() {
        // 普通类
        System.out.println(enumToListMap(TestEnum0.class));
        // 枚举类
        System.out.println(enumToListMap(TestEnum1.class));
        System.out.println(enumToListMap(TestEnum2.class));
        System.out.println(enumToListMap(TestEnum3.class));
    }

运行结果:

null
[]
[{name=TestEnum2}]
[{id=1, message=TestEnum3, desc=测试枚举类}]
  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 Java 中,自定义注解可以通过使用 `java.util.Map` 类型来声明参数。例如: ``` @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.METHOD) public @interface MyAnnotation { Map<String, String> parameters(); } ``` 这样,在使用该注解时,就可以传入一个字符串键值对的映射: ``` @MyAnnotation(parameters = { @KeyValue(key = "key1", value = "value1"), @KeyValue(key = "key2", value = "value2") }) public void myMethod() { // ... } ``` 其中,`@KeyValue` 是另一个自定义注解,用于声明键值对。 ### 回答2: Java 自定义注解 map 参数,可以通过使用反射技术来获取注解中的参数值。首先,需要定义一个注解类,使用 @interface 关键字声明,然后书写注解的属性。属性可以是基本类型,字符串,枚举类型等。其中,属性使用 @Retention 注解来指定其生命周期,使用 @Documented 注解来指定是否生成在 JavaDoc 中。 接着,在需要应用这个注解的地方,可以在方法、字段、类等位置使用注解。例如,可以在一个方法上使用注解,在方法的参数列表中定义一个 Map 参数,并在注解中指定 Map 的类型和要求。使用该注解后,可以通过反射获取注解,并进一步获取注解中定义的参数值。 在运行时,可以通过 Class 类的 getAnnotation() 方法获取注解,并通过注解类的相关方法获取注解的参数值。例如,可以通过 get方法来获取注解中的属性值,然后进行相应的逻辑处理。 使用自定义注解 map 参数可以增加程序的灵活性和扩展性。可以根据不同的需求定义不同的注解,并在不同的程序中应用,使程序更具有可配置性。此外,通过反射技术,可以在运行时动态获取注解的参数值,从而实现更为灵活的编程方式。 总之,Java 自定义注解 map 参数是一种方便灵活的编程方式,在需要传递 Map 参数的地方,可以通过自定义注解来定义并获取 Map 的类型和要求,从而实现更为灵活、可配置的程序设计。 ### 回答3: 在Java中,我们可以使用自定义注解来定义一种特殊的标记,用于提供额外的元数据信息。当然,我们也可以在注解中指定 Map 类型的参数。 首先,我们需要使用 @interface 关键字来定义一个注解,然后使用 @Retention 注解来指定注解的生命周期。接下来,我们可以使用 @Target 注解来指定注解可以应用的目标元素类型。 然后,我们可以在自定义注解中定义一个 Map 类型的参数。我们可以使用 @interface 关键字来定义注解的参数,并指定参数的名称、类型和默认值。例如: @Target(ElementType.METHOD) @Retention(RetentionPolicy.RUNTIME) public @interface CustomAnnotation { String name() default ""; int age() default 0; Map<String, String> properties() default {}; } 在上面的例子中,我们定义了一个 CustomAnnotation 注解,它可以应用于方法上,并包含三个参数:name、age 和 properties。其中 properties 是一个 Map 类型的参数,它的默认值为空的 Map。 使用这个自定义注解时,我们可以在注解中传入相应的参数值。例如: @CustomAnnotation(name = "Tom", age = 20, properties = {"key1=value1", "key2=value2"}) public void foo() { // 方法体 } 在上面的例子中,我们给 CustomAnnotation 注解的参数传递了相应的值,其中 properties 参数使用了数组的形式来传递多个键值对。 当我们需要使用自定义注解时,可以通过反射机制来获取注解的参数值。例如,我们可以通过以下方式获取 CustomAnnotation 注解的 properties 参数的值: CustomAnnotation annotation = getClass().getMethod("foo").getAnnotation(CustomAnnotation.class); Map<String, String> properties = annotation.properties(); 通过以上的方法,我们就可以在 Java 中使用自定义注解来传递 Map 类型的参数了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值