文档章节

使用反射将一个对象的值复制给另一个对象(同一个对象或者基于同一个基类)

指尖残雪
 指尖残雪
发布于 2016/05/22 23:56
字数 665
阅读 7
收藏 0

我写了两个方法:

第一个方法是一个类的不同实例化对象,比如类A,实例化对象a1,a2,:(使用的方法是得到类的属性名)

/**
     * 
     *<p>
     *@description 转换javabean ,将class2中的属性值赋值给class1,如果class1属性有值,则不覆盖
     *</p>
     *@param class1 基准类,被赋值对象
     *@param class2 提供数据的对象
     *@throws Exception
     * @see
     */
    private void converJavaBean(Object class1, Object class2) {
        Class<?> clazz1 = class1.getClass();
        Class<?> clazz2 = class2.getClass();
        Field[] fields1 = clazz1.getDeclaredFields();
        Field[] fields2 = clazz2.getDeclaredFields();
        for (int i = 0; i < fields1.length; i++) {
            try {
                fields1[i].setAccessible(true);
                fields2[i].setAccessible(true);
                Object obg1 = fields1[i].get(class1);
                Object obg2 = fields2[i].get(class2);

                if (null == fields1[i].get(class1) && null != fields2[i].get(class2)) {
                    fields1[i].set(class1, fields2[i].get(class2));
                }
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }
第二个方法得到get和set方法进行赋值,比第一个功能强大,只要有相同的属性名都可以

/**
     * 
     * <p>
     * 
     * @description 转换javabean ,将class2中的属性值赋值给class1,如果class1属性有值,则不覆盖
     *              ,前提条件是有相同的属性名
     *              </p>
     * @param class1
     *            基准类,被赋值对象
     * @param class2
     *            提供数据的对象
     * @throws Exception
     * @author ex_dingyongbiao
     * @see
     */
    public static void converJavaBean(Object class1, Object class2) {
        try {
            Class<?> clazz1 = class1.getClass();
            Class<?> clazz2 = class2.getClass();
            // 得到method方法
            Method[] method1 = clazz1.getMethods();
            Method[] method2 = clazz2.getMethods();

            int length1 = method1.length;
            int length2 = method2.length;
            if (length1 != 0 && length2 != 0) {
                // 创建一个get方法数组,专门存放class2的get方法。
                Method[] get = new Method[length2];
                for (int i = 0, j = 0; i < length2; i++) {
                    if (method2[i].getName().indexOf("get") == 0) {
                        get[j] = method2[i];
                        ++j;
                    }
                }

                for (int i = 0; i < get.length; i++) {
                    if (get[i] == null)// 数组初始化的长度多于get方法,所以数组后面的部分是null
                        continue;
                    // 得到get方法的值,判断时候为null,如果为null则进行下一个循环
                    Object value = get[i].invoke(class2, new Object[] {});
                    if (null == value)
                        continue;
                    // 得到get方法的名称 例如:getXxxx
                    String getName = get[i].getName();
                    // 得到set方法的时候传入的参数类型,就是get方法的返回类型
                    Class<?> paramType = get[i].getReturnType();
                    Method getMethod = null;
                    try {
                        // 判断在class1中时候有class2中的get方法,如果没有则抛异常继续循环
                        getMethod = clazz1.getMethod(getName, new Class[] {});
                    } catch (NoSuchMethodException e) {
                        continue;
                    }
                    // class1的get方法不为空并且class1中get方法得到的值为空,进行赋值,如果class1属性原来有值,则跳过
                    if (null == getMethod || null != getMethod.invoke(class1, new Object[] {}))
                        continue;
                    // 通过getName 例如getXxxx 截取后得到Xxxx,然后在前面加上set,就组装成set的方法名
                    String setName = "set" + getName.substring(3);
                    // 得到class1的set方法,并调用
                    Method setMethod = clazz1.getMethod(setName, paramType);
                    setMethod.invoke(class1, value);
                }
            }
        } catch(Exception e) {
        	System.out.println(e);
        }
    }
推荐使用第二种方法。


本文转载自:http://blog.csdn.net/bq1073100909/article/details/48413857

共有 人打赏支持
指尖残雪
粉丝 7
博文 73
码字总数 0
作品 0
上海
后端工程师
私信 提问
Java编程思想: 复用类

组合,继承与代理 何时初始化对象 编译器不会将每个对象均进行初始化. 在一个类中, 通常在下面三个地方进行对象的初始化: 1. 在定义对象的地方. 2. 在类的构造器中. 3. 在使用对象之前, 这称为...

fzyz_sb
2016/07/19
19
0
Java对象复制

1.Java对象复制概念 1.1 浅复制(浅克隆) 复制的对象的所有变量与含有与原来的对象相同的值,而所有的对其他对象的引用仍然指向原对象。换言之,浅复制仅仅复制所考虑的对象,而不复制它所引...

kukudeku
2016/09/30
40
0
[收藏]网上搜集的一系列C#面试题(持续更新……)

1.请你说说.NET中类和结构的区别? 答:结构和类具有大体的语法,但是结构受到的限制比类要多。结构不能申明有默认的构造函 数,为结构的副本是又编译器创建和销毁的,所以不需要默 认的构造函...

zting科技
2017/01/11
0
0
Java基础知识2

1、构造函数 通常用来在对象实例化时初始化对象的成员变量。 1)构造函数必须与类的名字相同,并且不能有返回值(也不能返回void) 2)每个类都有一个默认的无参构造函数,修饰符只与所在的c...

DouDouLee
2016/04/29
24
0
《Effective C#中文版:改善C#程序的50种方法》读书笔记

一、用属性代替可访问的字段 1、.NET数据绑定只支持数据绑定,使用属性可以获得数据绑定的好处; 2、在属性的get和set访问器重可使用lock添加多线程的支持。 二、readonly(运行时常量)和c...

晨曦之光
2012/03/09
77
0

没有更多内容

加载失败,请刷新页面

加载更多

Redis异构集群之间数据迁移方案

一、Redis集群迁移工具 最近在做Redis数据迁移,网上找了两款开源的Redis迁移工具。 第一种:redis-port Codis官方提供的一个工具,redis-port是一个Redis工具,通过解析rdb文件,实现Redis...

IT--小哥
1分钟前
0
0
MySQL5.7源码安装

5、MySQL源码安装(centos7.5) 5.1 下载软件 官方自带(boost版本mysql) wget https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-boost-5.7.20.tar.gz tar xf mysql-boost-5.7.20.tar.g......

hnairdb
4分钟前
0
0
解压zip包(zip4j)

1:引入zip4j_1.3.2.jar 2:源码如下: package test;import java.io.File;import java.io.IOException;import java.util.ArrayList;import java.util.List;import net.lingal......

uug
8分钟前
0
0
MySQL 8在CentOS 7用rpm安装

1.配置MySQL yum安装源和安装: #配置MySQL5.7的安装源 #https://repo.mysql.com/mysql57-community-release-el7.rpm #https://repo.mysql.com/mysql57-community-release-el7-11.noarch.rp......

MichaelShu
14分钟前
0
0
docker 安装zookeeper

1.下拉镜像: docker pull zookeeper 2.运行镜像: docker run --name myZookeeper --restart always -d zookeeper 此时,2181 2888 3888分别是zookeeper的(客户端端口,跟随端口,选择端口)...

狼王黄师傅
15分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部