java通过反射动态创建对象并给指定字段赋值

需求,动态更新表中不同的数据库字段

我有这样一个接口:

void updateColumn(Long id, Func1<Person, ?> column, Object val);

实体类:

@Data
class Person{
        private Long id;
        private String name;
        private String gender;
        private Integer age;
}

被调用的方式:

public static void main(String[] args) {
    updateColumn(1L,Person::getAge,18);
}

实现(这里使用到了hutool工具LambdaUtil):

  public Boolean updateColumn(Long id, Func1<Person, ?> column, Object val) {
        Class<Person> personClass = Person.class;

        // 反射创建对象
        Person person = null;
        try {
            person = personClass.getDeclaredConstructor().newInstance();
        } catch (InstantiationException | IllegalAccessException | InvocationTargetException | NoSuchMethodException e) {
            e.printStackTrace();
        }

        // 获取Field
        Field field = null;
        try {
            // 通过column获取真正的字段名
            field = personClass.getDeclaredField(LambdaUtil.getFieldName(column));
        } catch (NoSuchFieldException e) {
            e.printStackTrace();
        }

        // 设置字段的可访问性,以便设置私有字段
        field.setAccessible(true);

        // 将val转换为column的类型
        final Class<?> type = field.getType();
        final Object value = type.cast(val);

        // 将val的值赋给Person对象的column字段
        try {
            field.set(person, value);
        } catch (IllegalAccessException e) {
            e.printStackTrace();
        }

        // todo 这个person对象就是需要更新的对象
        return false;
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
您好,根据excel字段名称给对象对应字段赋值这个问题可以通过使用反射来实现。您可以通过读取excel中的字段名称以及字段值,然后通过反射的方式动态地为对象的相应字段赋值。具体实现可以参考以下代码: ```java import java.lang.reflect.Field; public class ObjectReflectUtil { /** * 根据excel字段名称给对象对应字段赋值 * * @param obj 待赋值的对象 * @param field 字段名称 * @param value 字段值 * @param <T> 对象类型 * @throws NoSuchFieldException 没有找到相应的字段 * @throws IllegalAccessException 字段为私有的,无法访问 */ public static <T> void setFieldByName(T obj, String field, Object value) throws NoSuchFieldException, IllegalAccessException { Field declaredField = obj.getClass().getDeclaredField(field); declaredField.setAccessible(true); declaredField.set(obj, value); } } ``` 使用示例: ```java public class Demo { public static void main(String[] args) throws NoSuchFieldException, IllegalAccessException { // 创建一个包含两个字段的对象 User user = new User(); // 读取excel中的字段名称和字段值 String fieldName = "age"; Object fieldValue = 20; // 给对象对应字段赋值 ObjectReflectUtil.setFieldByName(user, fieldName, fieldValue); System.out.println(user.getAge()); // 输出:20 } } class User { private String name; private int age; public User() { } public User(String name, int age) { this.name = name; this.age = age; } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } } ``` 希望能够帮到您!

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

L-960

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

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

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

打赏作者

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

抵扣说明:

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

余额充值