内容简介:目录树概述Apache BeanUtils将Bean转Map
目录树
概述
Apache BeanUtils将Bean转Map
Apache BeanUtils将Map转Bean
理解BeanUtils将Bean转Map的实现之手写Bean转Map
概述
Apache的BeanUtils Bean工具类很强大,基本涵盖了Bean操作的所有方法。这里的话我们就讲讲两个方面,一是Bean covert to Map,二是Map covert to Bean;Bean转Map其实利用的是 Java 的动态性-Reflection技术,不管是什么Bean通过动态解析都是可以转成Map对象的,但前提条件是field需要符合驼峰命名不过这也是写码规范,另一个条件就是每个field需要getter、setter方法。而Map转Bean一样也是通过Reflection动态解析成Bean。Java的Reflection其实是挺重要的,我们用的很多 工具 类都有它的存在,我们不止要会用而且更重要的是能够理解是为什么,最好是自己去手写实现这样的话更能加深理解。
用Apache BeanUtils将Bean转Map
代码实现
1 /*
2 用apache的BeanUtils实现Bean covert to Map
3 @throws Exception
4 /
5 public static void beanToMap() throws Exception {
6 User user=new User();
7 Map<String,String> keyValues=null;
8
9 user.setPassWord("password");
10 user.setComments("test method!");
11 user.setUserName("wang shisheng");
12 user.setCreateTime(new Date());
13
14 keyValues=BeanUtils.describe(user);
15
16 LOGGER.info("bean covert to map:{}", JSONObject.toJSON(keyValues).toString());
17 }
测试结果
用Apache BeanUtils将Map转Bean
代码实现
1 /*
2 用apache的BeanUtils实现Map covert to Bean
3 @throws Exception
4 /
5 public static void mapToBean() throws Exception {
6 Map<String,String> keyValues=new HashMap<>();
7 User user=new User();
8
9 keyValues.put("sessionId","ED442323232ff3");
10 keyValues.put("userName","wang shisheng");
11 keyValues.put("passWord","xxxxx44333");
12 keyValues.put("requestNums","34");
13
14 BeanUtils.populate(user,keyValues);
15
16 LOGGER.info("map covert to bean:{}", user.toString());
17 }
测试结果
理解BeanUtils将Bean转Map的实现之手写Bean转Map
代码实现
/**
•应用反射(其实工具类底层一样用的反射技术)
•手动写一个 Bean covert to Map
*/
public static void autoBeanToMap(){
User user=new User();
Map<String,Object> keyValues=new HashMap<>();
user.setPassWord("password");
user.setComments("test method!");
user.setUserName("wang shisheng");
user.setUserCode("2018998770");
user.setCreateTime(new Date());
Method[] methods=user.getClass().getMethods();
try {
for(Method method: methods){
String methodName=method.getName();
//反射获取属性与属性值的方法很多,以下是其一;也可以直接获得属性,不过获取的时候需要用过设置属性私有可见
if (methodName.contains("get")){
//invoke 执行get方法获取属性值
Object value=method.invoke(user);
//根据setXXXX 通过以下算法取得属性名称
String key=methodName.substring(methodName.indexOf("get")+3);
Object temp=key.substring(0,1).toString().toLowerCase();
key=key.substring(1);
//最终得到属性名称
key=temp+key;
keyValues.put(key,value);
}
}
}catch (Exception e){
LOGGER.error("错误信息:",e);
}
LOGGER.info("auto bean covert to map:{}", JSONObject.toJSON(keyValues).toString());
}
测试结果
Linux公社的RSS地址 : https://www.linuxidc.com/rssFeed.aspx
本文永久更新链接地址: https://www.linuxidc.com/Linux/2018-10/154637.htm
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- Go 语言函数式编程系列教程(七) —— 数据类型篇:基本数据类型之间的转化
- js的类型转化三两事儿
- archTIS:将数据安全转化为经济增长
- 如何将JavaScript转化成Swift?(一)
- python3 第十章 - 如何进行进制转化
- 用Golang将图片转化成ASCII码
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
海量运维、运营规划之道
唐文 / 电子工业出版社 / 2014-1-1 / 59.00
《海量运维、运营规划之道》作者具有腾讯、百度等中国一线互联网公司多年从业经历,书中依托工作实践,以互联网海量产品质量、效率、成本为核心,从规划、速度、监控、告警、安全、管理、流程、预案、考核、设备、带宽等方面,结合大量案例与读者分享了作者对互联网海量运维、运营规划的体会。 《海量运维、运营规划之道》全面介绍大型互联网公司运维工作所涉及的各个方面,是每个互联网运维工程师、架构师、管理人员不可或......一起来看看 《海量运维、运营规划之道》 这本书的介绍吧!