项目背景
我们开发过程中会碰到这样一类问题,就是数据层或三方接口返回的Bean对象需要转换重新装换一下我们需要的对象。我们通常的做法就是通过getter/setter方法进行一个一个进行赋值,这样的话书写起来太复杂了,并且太重复了。我尝试写了一个工具类,能够对各种场景下的对象进行相互赋值。
功能介绍
- 可以为将要赋值的对象进行单个单个的按顺序赋值
- 通过传递的属性的index(就是他是第几个属性)获取本属性的值
- 返回对象中属性的数量
- 两个对象之间相互拷贝属性值
- 传递一个list,遍历bean进行赋值
- 传递一个数组,对对象进行赋值
- 返回一个对象的属性值集合
- 返回一个对象的属性值数组
注意注意注意!!!
getDeclaredFields方法不能保证字段声明的顺序进行返回,但是基本上会按照这个顺序的。所以以下的方法是建立在返回正确的顺序上的基础上的,但是两个对象相互拷贝是没有问题的。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 | import java.lang.reflect.Field; import java.util.ArrayList; import java.util.List; /** * @author haoyan.shi * 想设计一个能够解析一个bean的全部属性并按照顺序进行遍历 */ public class ObjectUtils { /** * 按照属性的顺序赋值。可接受null,但是不能跳过某个属性进行赋值。就是说就算 * 有一个值为空,那你也要传递进行null * * @param target * @param value * @param <E> * @return */ public static <E> E forEachSetValue(E target, Object value) { if (target == null ) { return target; } List<Field> fields = new ArrayList<>(); try { // 1.解析出所有的属性 Field[] declaredFields = target.getClass().getDeclaredFields(); for (Field declaredField : declaredFields) { declaredField.setAccessible( true ); fields.add(declaredField); } // 2.把每个属性放入一个集合中 if (fields.size() <= 0 ) { return target; } while (fields.get( 0 ).get(target) != null ) { fields.remove( 0 ); } Field field = fields.get( 0 ); field.set(target, value); fields.remove( 0 ); } catch (Exception exception) { exception.printStackTrace(); } return target; } /** * 本方法为了遍历索引进行赋值 * * @param e * @param index * @return */ public static Object forEachGetValue(Object e, int index) { try { Field[] declaredFields = e.getClass().getDeclaredFields(); for (Field declaredField : declaredFields) { declaredField.setAccessible( true ); } return declaredFields[index].get(e); } catch (IllegalAccessException illegalAccessException) { illegalAccessException.printStackTrace(); } return e; } public static int size(Object o) { if (o == null ) { return 0 ; } Field[] declaredFields = o.getClass().getDeclaredFields(); return declaredFields.length; } /** * 本方法是为了把已经有值得对象中属性名相同的名属性赋值到没有值得对象用。 * * @param target * @param value */ public static <E> E copyValueFromObject(E target, Object value) { if (target == null || value == null ) { return null ; } Field[] vs = target.getClass().getDeclaredFields(); Field[] ts = value.getClass().getDeclaredFields(); try { for ( int i = 0 ; i < vs.length; i++) { for ( int j = 0 ; j < ts.length; j++) { if (vs[i].getName().equals(ts[j])) { ts[j].set(target, vs[i].get(value)); } } } } catch (Exception e) { e.printStackTrace(); } return target; } /** * 这个方法能把list中的值按照顺序设置到目标对象中 * * @param target * @param value * @param <E> * @return */ public static <E> E forEachSetValueFromList(E target, List value) { if (target == null || value == null || value.size() == 0 ) { return target; } Field[] ts = target.getClass().getDeclaredFields(); try { for ( int i = 0 ; i < ts.length; i++) { ts[i].set(target, value.get(i)); } } catch (Exception e) { e.printStackTrace(); } return target; } /** * 从数组中进行设置值 * * @param target * @param value * @param <E> * @return */ public static <E> E forEachSetValueFromArray(E target, Object[] value) { if (target == null || value == null || value.length == 0 ) { return target; } Field[] ts = target.getClass().getDeclaredFields(); try { for ( int i = 0 ; i < ts.length; i++) { ts[i].set(target, value[i]); } } catch (Exception e) { e.printStackTrace(); } return target; } public static Object[] getArrayValue(Object o) { Field[] declaredFields = o.getClass().getDeclaredFields(); Object[] result = new Object[declaredFields.length]; try { for ( int i = 0 ; i < declaredFields.length; i++) { result[i] = declaredFields[i].get(o); } } catch (Exception e) { e.printStackTrace(); } return result; } public static List getListValue(Object o) { Field[] declaredFields = o.getClass().getDeclaredFields(); List result = new ArrayList(declaredFields.length); try { for ( int i = 0 ; i < declaredFields.length; i++) { result.add(declaredFields[i].get(o)); } } catch (Exception e) { e.printStackTrace(); } return result; } } |
后期扩展:
1.我们可以定义一些注解,进行属性匹配。注入值更精确。
2.还可以用jdk1.8中的函数接口,进行赋值。
3.甚至都可以作为jdk的新特性去扩展这个功能。
到此这篇关于Java循环对bean的属性进行赋值的文章就介绍到这了,更多相关Javabean属性赋值内容请搜索自学编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持自学编程网!
- 本文固定链接: https://zxbcw.cn/post/220313/
- 转载请注明:必须在正文中标注并保留原文链接
- QQ群: PHP高手阵营官方总群(344148542)
- QQ群: Yii2.0开发(304864863)