Java中的Map如何转实体类对象【附工具类相关方法】

简介: Java中的Map如何转实体类对象【附工具类相关方法】

写在前面


最近在写一个小需求,中途遇到这么一个问题,总而言之,就是在java中,如何将对应的Map,转换成相应的实体类对象。


并且保证相应的参数值都能在实体类对象中赋值。


这个问题其实还是挺简单的,但是其中还是要大概分为两种情况。


其一,当实体类中所有的属性,都能在Map集合中取到的情况,当然Map中是否有其他超出实体类属性的不关心。


其二,当实体类中所有的属性,不能在Map集合中取到的情况。


解决方案


为了解决这两种情况,我们来稍作处理。


第一种的情况,其实还是非常标准的转换情况,所以通常我们会使用反射来处理这种情况,我们也提供了相应的方法,如下:


public static Object map2Bean(Map<String, Object> map, Object object) {
    if (map == null || object == null) {
        return null;
    }
    try {
        BeanInfo beanInfo = Introspector.getBeanInfo(object.getClass());
        PropertyDescriptor[] propertyDescriptors = beanInfo.getPropertyDescriptors();
        for (PropertyDescriptor property : propertyDescriptors) {
            String key = property.getName();
            if (map.containsKey(key)) {
                Object value = map.get(key);
                // 得到property对应的setter方法
                Method setter = property.getWriteMethod();
                setter.invoke(object, value);
            }
        }
    } catch (IntrospectionException | InvocationTargetException | IllegalAccessException e) {
        e.printStackTrace();
    }
    return object;
}


第二种的情况,稍微不太标准的情况,所以我们就不能通过反射setter方法来处理了,只能通过获取相应的属性来进行填充数据,如下:


public static Object mapToObject(Map<String, Object> map, Class<?> beanClass) throws Exception {
    if (map == null) {
        return null;
    }
    Object object = beanClass.newInstance();
    Field[] fields = beanClass.getDeclaredFields();
    Field[] superFields = beanClass.getSuperclass().getDeclaredFields();
    convert(map, object, fields);
    convert(map, object, superFields);
    return object;
}
private static void convert(Map<String, Object> map, Object object, Field[] fields) throws IllegalAccessException {
    for (Field field : fields) {
        int mod = field.getModifiers();
        if (Modifier.isFinal(mod) || Modifier.isStatic(mod) || ValidateUtils.isEmpty(map.get(field.getName()))) {
            continue;
        }
        field.setAccessible(true);
        field.set(object, ConvertUtils.convert(map.get(field.getName()), field.getType()));
    }
}


这里面要说一下Field[] superFields = beanClass.getSuperclass().getDeclaredFields();这行代码,是获取继承的父级属性,如果大家不需要可以自行删除。


相关文章
|
9天前
|
安全 Java 编译器
Java对象一定分配在堆上吗?
本文探讨了Java对象的内存分配问题,重点介绍了JVM的逃逸分析技术及其优化策略。逃逸分析能判断对象是否会在作用域外被访问,从而决定对象是否需要分配到堆上。文章详细讲解了栈上分配、标量替换和同步消除三种优化策略,并通过示例代码说明了这些技术的应用场景。
Java对象一定分配在堆上吗?
|
12天前
|
Java API
Java 对象释放与 finalize 方法
关于 Java 对象释放的疑惑解答,以及 finalize 方法的相关知识。
35 17
|
7天前
|
存储 Java API
Java交换map的key和value值
通过本文介绍的几种方法,可以在Java中实现Map键值对的交换。每种方法都有其优缺点,具体选择哪种方法应根据实际需求和场景决定。对于简单的键值对交换,可以使用简单遍历法或Java 8的Stream API;对于需要处理值不唯一的情况,可以使用集合存储或Guava的Multimap。希望本文对您理解和实现Java中的Map键值对交换有所帮助。
10 1
|
12天前
|
存储 安全 Java
Java编程中的对象序列化与反序列化
【10月更文挑战第22天】在Java的世界里,对象序列化和反序列化是数据持久化和网络传输的关键技术。本文将带你了解如何在Java中实现对象的序列化与反序列化,并探讨其背后的原理。通过实际代码示例,我们将一步步展示如何将复杂数据结构转换为字节流,以及如何将这些字节流还原为Java对象。文章还将讨论在使用序列化时应注意的安全性问题,以确保你的应用程序既高效又安全。
|
15天前
|
存储 Java API
优雅地使用Java Map,通过掌握其高级特性和技巧,让代码更简洁。
【10月更文挑战第19天】本文介绍了如何优雅地使用Java Map,通过掌握其高级特性和技巧,让代码更简洁。内容包括Map的初始化、使用Stream API处理Map、利用merge方法、使用ComputeIfAbsent和ComputeIfPresent,以及Map的默认方法。这些技巧不仅提高了代码的可读性和维护性,还提升了开发效率。
36 3
|
15天前
|
存储 Java API
详细解析HashMap、TreeMap、LinkedHashMap等实现类,帮助您更好地理解和应用Java Map。
【10月更文挑战第19天】深入剖析Java Map:不仅是高效存储键值对的数据结构,更是展现设计艺术的典范。本文从基本概念、设计艺术和使用技巧三个方面,详细解析HashMap、TreeMap、LinkedHashMap等实现类,帮助您更好地理解和应用Java Map。
34 3
|
15天前
|
存储 缓存 安全
在Java的Map家族中,HashMap和TreeMap各具特色
【10月更文挑战第19天】在Java的Map家族中,HashMap和TreeMap各具特色。HashMap基于哈希表实现,提供O(1)时间复杂度的高效操作,适合性能要求高的场景;TreeMap基于红黑树,提供O(log n)时间复杂度的有序操作,适合需要排序和范围查询的场景。两者在不同需求下各有优势,选择时需根据具体应用场景权衡。
20 2
|
12天前
|
存储 缓存 NoSQL
一篇搞懂!Java对象序列化与反序列化的底层逻辑
本文介绍了Java中的序列化与反序列化,包括基本概念、应用场景、实现方式及注意事项。序列化是将对象转换为字节流,便于存储和传输;反序列化则是将字节流还原为对象。文中详细讲解了实现序列化的步骤,以及常见的反序列化失败原因和最佳实践。通过实例和代码示例,帮助读者更好地理解和应用这一重要技术。
9 0
|
2月前
|
存储 Java
Java编程中的对象和类
【8月更文挑战第55天】在Java的世界中,“对象”与“类”是构建一切的基础。就像乐高积木一样,类定义了形状和结构,而对象则是根据这些设计拼装出来的具体作品。本篇文章将通过一个简单的例子,展示如何从零开始创建一个类,并利用它来制作我们的第一个Java对象。准备好让你的编程之旅起飞了吗?让我们一起来探索这个神奇的过程!
30 10
|
2月前
|
存储 Java
Java的对象和类的相同之处和不同之处
在 Java 中,对象和类是面向对象编程的核心。