反射获取当前私有字段和父类私有字段的值

本文介绍了一种将Java对象转换为Map的方法,通过反射机制遍历对象的所有字段,并将其键值对存储到Map中,适用于对象属性的快速转换场景。

写了一个将对象转换成map的方法可以参考

 public static  Map<String,Object> getObjectToMap(Object t) throws IllegalAccessException {
            Class className = t.getClass();
            Map<String,Object> param=new HashMap<>();
            for(; className != Object.class ; className = className.getSuperclass()) {//获取本身和父级对象
                Field[] fields = className.getDeclaredFields();//获取所有私有字段
                for (Field field : fields) {
                    field.setAccessible(true);
                    param.put(field.getName(), field.get(t)==null?"":field.get(t));
                }
            }
        return param;
    }
### 使用 ReflectUtil 获取类及其父类字段名称与 为了获取指定类及其所有父类字段名称与其对应的,可以采用递归遍历的方式。先从目标类开始,逐步向上追溯到其父类,直到达到 `Object` 类为止。 在 Java 中,反射机制允许程序在运行时检查或“自省”自身,并能够操作内部属性。这里提到的 `ReflectUtil` 并不是一个标准库的一部分,而是指 Spring 框架下的工具类 `org.springframework.util.ReflectionUtils`[^4]。此工具提供了便捷的方法用于访问私有字段、调用方法等操作,简化了传统反射API带来的复杂度。 下面是一个基于 `ReflectionUtils` 实现的例子: ```java import org.springframework.util.ReflectionUtils; import java.lang.reflect.Field; import java.util.HashMap; import java.util.Map; public class FieldValueExtractor { public static Map<String, Object> getAllFieldsAndValues(Object obj) { Class<?> clazz = obj.getClass(); Map<String, Object> fieldMap = new HashMap<>(); while (clazz != null && !clazz.equals(Object.class)) { // 防止无限循环至顶级对象 Field[] fields = clazz.getDeclaredFields(); // 取得当前类声明的所有字段 for (Field field : fields) { ReflectionUtils.makeAccessible(field); // 设置可访问性 try { String fieldName = field.getName(); Object fieldValue = ReflectionUtils.getField(field, obj); if (!fieldMap.containsKey(fieldName)) fieldMap.put(fieldName, fieldValue); } catch (Exception e) { System.out.println("Error accessing field: " + field.getName()); } } clazz = clazz.getSuperclass(); // 转向父类继续查找 } return fieldMap; } } ``` 这段代码定义了一个名为 `FieldValueExtractor` 的辅助类,其中包含了静态方法 `getAllFieldsAndValues()` 来收集给定对象的所有字段它们的实际。该函数接受任意类型的对象作为输入参数,并返回一个映射表,键为字段的名字而则为此字段的具体数。注意,在处理每个字段之前都会尝试将其设为可访问状态以便于读取 private 字段的内容。 此外,考虑到可能存在的重复字段(即子类覆盖了来自超类同名但不同作用域级别的字段),上述实现只保留第一次遇到的那个版本;如果希望优先考虑更具体的子类定义,则可以在判断是否已存在相同 key 后调整逻辑顺序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值