反射技术Get OR Set 多继承模式子类和父类属性,方法

反射技术Get OR Set 多继承模式子类和父类属性,方法

这些都是等一下会调用的工具类,具体入参说明都有注释


import java.lang.reflect.Field;
import org.springframework.util.ReflectionUtils;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;



/**
 * @ClassName ReflectUtils 
 * @Description 反射方法支持多级继承子父类方法以及属性操作工具类
 * @Author liyahui
 * @Date 2021-1-14 10:58
 * @Version 1.0
 */
public class ReflectUtils {

   /**
     * 获取本类及其父类的属性的方法
     *
     * @param obj 当前类对象
     * @return 字段数组
     */
    private static Field[] getAllFields(Object obj) {
        Class clazz = obj.getClass();
        List<Field> fieldList = new ArrayList<>();
        while (clazz != null) {
            fieldList.addAll(new ArrayList<>(Arrays.asList(clazz.getDeclaredFields())));
            clazz = clazz.getSuperclass();
        }
        Field[] fields = new Field[fieldList.size()];
        fieldList.toArray(fields);
        return fields;
    }

    /**
     * 根据字段名称以及Class对象,查询字段
     *
     * @param tar   字段名称
     * @param clazz 对象
     */
    public static Field getFiled(String tar, Class clazz) {
        String error = null;
        Field field = null;
        while (clazz != null) {
            try {
                field = clazz.getDeclaredField(tar);
                error = null;
                break;
            } catch (Exception e) {
                clazz = clazz.getSuperclass();
                error = e.getMessage();
            }
        }
        if (error != null || field == null) {
            throw new RuntimeException("无法获取源字段:" + tar);
        }
        return field;
    }

    /**
     * 根据字段名称以及newInstance返回对象以及Class<?> 对象查询值
     *
     * @param filedName 字段名称
     * @param o         newInstance返回对象
     * @param clazz     Class<?> 对象
     */
    public static Object getValueByPropName(String filedName, Object o, Class clazz) {
        Field field = getFiled(filedName, clazz);
        field.setAccessible(true);
        return org.springframework.util.ReflectionUtils.getField(field, o);
    }

    /**
     * 根据反射机制set对象属性
     *
     * @param tar   字段名称
     * @param o     newInstance返回对象
     * @param val   set的数据值
     * @param clazz Class<?> 对象
     */
    public static void setValueByPropName(String tar, Object o, Object val, Class clazz) {
        Field field = getFiled(tar, clazz);
        field.setAccessible(true);
        ReflectionUtils.setField(field, o, val);
    }
}

创建3个类,进行互相继承A extends B, B extends C
在这里插入图片描述
编写测试类进行测试

package com.example.manage.reflect;

import com.alibaba.fastjson.JSON;
import org.springframework.util.ReflectionUtils;

import java.lang.reflect.Field;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Date;
import java.util.List;

/**
 * @ClassName ReflectDemo
 * @Description 该反射方法支持多级继承子父类方法以及属性操作
 * @Author liyahui
 * @Date 2021-1-14 10:58
 * @Version 1.0
 */
public class ReflectDemo {

    public static void main(String[] args) {
        reflectParent();
    }

    public static void reflectParent() {
        Object instance = null;
        Class<?> c = null;
        try {
            c = Class.forName("com.example.manage.reflect.A");
            instance = c.newInstance();
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        } catch (IllegalAccessException e) {
            e.printStackTrace();
        } catch (InstantiationException e) {
            e.printStackTrace();
        }
        Field[] fields = getAllFields(instance);
        for (int i = 0; i < fields.length; i++) {
            String type = fields[i].getGenericType().toString();
            switch (type) {
                case "class java.lang.String":
                    setValueByPropName(fields[i].getName(), instance, "str", c);
                    break;
                case "class java.lang.Integer":
                    setValueByPropName(fields[i].getName(), instance, 1, c);
                    break;
                case "class java.lang.Boolean":
                    setValueByPropName(fields[i].getName(), instance, true, c);
                    break;
                case "class java.lang.Long":
                    setValueByPropName(fields[i].getName(), instance, 2L, c);
                    break;
                case "class java.util.Date":
                    setValueByPropName(fields[i].getName(), instance, new Date(), c);
                    break;
                case "class java.lang.Double":
                    setValueByPropName(fields[i].getName(), instance, 1.0, c);
                    break;
                default:
                    break;
            }
        }
        System.out.println(JSON.toJSONString((A) instance));
    }
       /**
         *  在这下面可以编写调用数据库操作的一些代码
         * */
        /************************************************/
        // TODO: 2021-1-14 XXXMapper.save((A) instance); 
        /************************************************/
}
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中,子类可以通过以下两种方式调用父类的get和set方法: 1. 使用super关键字:子类可以使用super关键字来调用父类方法。通过super,子类可以访问父类的成员变量和方法。例如,如果父类中有一个名为"getName"的方法子类可以使用super.getName()来调用该方法。 2. 继承父类方法子类可以继承父类方法,包括get和set方法继承后,子类可以直接调用这些方法,就像调用自己的方法一样。例如,如果父类中有一个名为"getName"的方法子类可以直接使用getName()来调用该方法。 下面是一个简单的示例代码,演示了子类如何调用父类的get和set方法: ```java // 父类 class Parent { private String name; public String getName() { return name; } public void setName(String name) { this.name = name; } } // 子类 class Child extends Parent { private int age; public int getAge() { return age; } public void setAge(int age) { this.age = age; } } // 测试 public class Main { public static void main(String[] args) { Child child = new Child(); child.setName("John"); // 调用父类setName方法 child.setAge(20); // 调用子类自己的setAge方法 System.out.println(child.getName()); // 调用父类的getName方法 System.out.println(child.getAge()); // 调用子类自己的getAge方法 } } ``` 在上面的示例中,子类Child继承父类Parent的getName和setName方法,可以直接调用这些方法。同时,子类Child还定义了自己的getAge和setAge方法。在测试代码中,我们创建了Child对象child,并分别调用了父类的getName方法子类的getAge方法以及父类setName和子类setAge方法
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值