java中map和对象互转工具类的实现示例
在项目开发中,经常碰到map转实体对象或者对象转map的场景,工作中,很多时候我们可能比较喜欢使用第三方jar包的API对他们进行转化,而且用起来也还算方便,比如像fastJson就可以轻松实现map和对象的互转,但这里,我想通过反射的方式对他们做转化,也算是对反射的学习和研究吧;
1、map转对象;
主要思路,将map中的key-value取出来,然后和给定的对象去匹配,为了使工具方法更具通用性,直接通过反射的方式将给定对象的属性获取到,然后调用反射相关的API和map中的key-value进行匹配即可,下面直接上代码,
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
|
/** * 利用反射将map集合封装成bean对象 * * @param params * @param clazz * @return */ public static <T> T mapToBean(Map<String, Object> map, Class<?> clazz) throws Exception { Object obj = clazz.newInstance(); if (map != null && !map.isEmpty() && map.size() > 0 ) { for (Map.Entry<String, Object> entry : map.entrySet()) { String propertyName = entry.getKey(); // 属性名 Object value = entry.getValue(); // 属性值 String setMethodName = "set" + propertyName.substring( 0 , 1 ).toUpperCase() + propertyName.substring( 1 ); Field field = getClassField(clazz, propertyName); //获取和map的key匹配的属性名称 if (field == null ){ continue ; } Class<?> fieldTypeClass = field.getType(); value = convertValType(value, fieldTypeClass); try { clazz.getMethod(setMethodName, field.getType()).invoke(obj, value); } catch (NoSuchMethodException e) { e.printStackTrace(); } } } return (T) obj; } /** * 根据给定对象类匹配对象中的特定字段 * @param clazz * @param fieldName * @return */ private static Field getClassField(Class<?> clazz, String fieldName) { if (Object. class .getName().equals(clazz.getName())) { return null ; } Field[] declaredFields = clazz.getDeclaredFields(); for (Field field : declaredFields) { if (field.getName().equals(fieldName)) { return field; } } Class<?> superClass = clazz.getSuperclass(); //如果该类还有父类,将父类对象中的字段也取出 if (superClass != null ) { //递归获取 return getClassField(superClass, fieldName); } return null ; } /** * 将map的value值转为实体类中字段类型匹配的方法 * @param value * @param fieldTypeClass * @return */ private static Object convertValType(Object value, Class<?> fieldTypeClass) { Object retVal = null ; if (Long. class .getName().equals(fieldTypeClass.getName()) || long . class .getName().equals(fieldTypeClass.getName())) { retVal = Long.parseLong(value.toString()); } else if (Integer. class .getName().equals(fieldTypeClass.getName()) || int . class .getName().equals(fieldTypeClass.getName())) { retVal = Integer.parseInt(value.toString()); } else if (Float. class .getName().equals(fieldTypeClass.getName()) || float . class .getName().equals(fieldTypeClass.getName())) { retVal = Float.parseFloat(value.toString()); } else if (Double. class .getName().equals(fieldTypeClass.getName()) || double . class .getName().equals(fieldTypeClass.getName())) { retVal = Double.parseDouble(value.toString()); } else { retVal = value; } return retVal; } |
我们写一个测试方法来验证一下上述代码,我提前建好了一个实体类productInfo,
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
|
public class ProductInfo { private Long id; private String name; private Double price; public Long getId() { return id; } public void setId(Long id) { this .id = id; } public String getName() { return name; } public void setName(String name) { this .name = name; } public Double getPrice() { return price; } public void setPrice(Double price) { this .price = price; } public ProductInfo(Long id, String name, Double price) { super (); this .id = id; this .name = name; this .price = price; } public ProductInfo() { super (); } @Override public String toString() { return "ProductInfo [id=" + id + ", name=" + name + ", price=" + price + "]" ; } } |
1
2
3
4
5
6
7
8
|
public static void main(String[] args) throws Exception { Map<String, Object> param = new HashMap<>(); param.put( "id" , 12232 ); param.put( "name" , "banana" ); param.put( "price" , 12.25 ); ProductInfo info = mapToBean(param, ProductInfo. class ); System.out.println(info.getName()); } |
运行main函数,查看结果,可以看到控制台已经成功打印出结果,
2、对象转map,
思路,同上述的分析类似,这不过这里需要反过来,给定一个待转化的实体类,通过反射,将实体类中的字段名称和字段值获取到,然后一一设置到map的key-value中,下面看代码,
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
|
/** * 对象转map * @param obj * @return */ private static Map<String, Object> objToMap(Object obj) { Map<String, Object> map = new HashMap<String, Object>(); Field[] fields = obj.getClass().getDeclaredFields(); // 获取f对象对应类中的所有属性域 for ( int i = 0 , len = fields.length; i < len; i++) { String varName = fields[i].getName(); varName = varName.toLowerCase(); // 将key置为小写,默认为对象的属性 try { boolean accessFlag = fields[i].isAccessible(); // 获取原来的访问控制权限 fields[i].setAccessible( true ); // 修改访问控制权限 Object o = fields[i].get(obj); // 获取在对象f中属性fields[i]对应的对象中的变量 if (o != null ){ map.put(varName, o.toString()); } fields[i].setAccessible(accessFlag); // 恢复访问控制权限 } catch (IllegalArgumentException ex) { ex.printStackTrace(); } catch (IllegalAccessException ex) { ex.printStackTrace(); } } return map; } |
下面写个测试方法,
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
public static void main(String[] args) throws Exception { Map<String, Object> param = new HashMap<>(); param.put( "id" , 12232 ); param.put( "name" , "banana" ); param.put( "price" , 12.25 ); ProductInfo info = mapToBean(param, ProductInfo. class ); System.out.println(info.getName()); System.out.println( "---------------------" ); Map<String, Object> map = objToMap(info); System.out.println( "对象转map后的结果 : " + map); } |
运行,查看控制台的输出结果,说明已经成功转化,
以上,就是map和对象之间实现互相转化的工具类,各位今后工作中如有需要可直接拿去使用,不足之处,敬请见谅哈!也希望大家多多支持脚本之家。
https://blog.csdn.net/u011191463/article/details/60579191
https://blog.csdn.net/qq_22596931/article/details/86637540
https://www.jb51.net/article/167715.htm
java中map和对象互转工具类的实现示例的更多相关文章
- java中模拟http(https)请求的工具类
在java中,特别是java web中,我们经常需要碰到的一个场景是我们需要从服务端去发送http请求,获取到数据,而不是直接从浏览器输入请求网址获得相应.比如我们想访问微信接口,获取其返回信息. 在 ...
- java中Map等对象转换为json
ObjectMapper objectMapper = new ObjectMapper(); String jsonString = objectMapper.writeValueAsString( ...
- java中线程的停止以及LockSupport工具类
看jstack输出的时候,可以发现很多状态都是TIMED_WAITING(parking),如下所示: "http-bio-8080-exec-16" #70 daemon pri ...
- 总结的一些json格式和对象/String/Map/List等的互转工具类
总结的一些json格式和对象/String/Map/List等的互转工具类,有需要的可以看看,需要引入jackson-core-asl-1.7.1.jar.jackson-jaxrs-1.7.1.ja ...
- 将java中Map对象转为有相同属性的类对象(json作为中间转换)
java中Map对象转为有相同属性的类对象(json作为中间转换) 准备好json转换工具类 public class JsonUtil { private static ObjectMapper o ...
- (转)java中对集合对象list的几种循环访问总结
Java集合的Stack.Queue.Map的遍历 在集合操作中,常常离不开对集合的遍历,对集合遍历一般来说一个foreach就搞定了,但是,对于Stack.Queue.Map类型的遍历,还是有一 ...
- java中map接口hashMap以及Enty之间的用法和关系
java中map接口hashMap以及Enty之间的转换 首先说的是map接口: Map提供了一种映射关系,其中的元素是以键值对(key-value)的形式存储的,能够实现根据key快速查找value ...
- 细说java中Map的两种迭代方式
曾经对java中迭代方式总是迷迷糊糊的,今天总算弄懂了.特意的总结了一下.基本是算是理解透彻了. 1.再说Map之前先说下Iterator: Iterator主要用于遍历(即迭代訪问)Collecti ...
- java中Map,List与Set的差别
java中Map,List与Set的差别 java集合的主要分为三种类型: Set(集) List(列表) Map(映射) 要深入理解集合首先要了解下我们熟悉的数组: 数组是大小固定的,而且同一个数组 ...
随机推荐
- 马哥docker听课记录
容器技术:chroot.namespaces.cgroups docker平时用户空间只运行一个进程,只运行在一个namespaces中 镜像:分层构建.联合挂载 容器编排工具:kubernetes ...
- python写入csv文件时的乱码问题
今天在使用python的csv库将数据写入csv文件时候,出现了中文乱码问题,解决方法是在写入文件前,先指定utf-8编码,如下: import csv import codecs if __name ...
- cetos报错“Lack of free swap space” 解决方法
前提:今天发现某台主机一直报警:swap内存被用光 1.查看了服务器的内存情况[发现在物理内存还剩余的情况下,swap开始被使用,甚至到被用光][root@note1 ~]# free -htotal ...
- httprunner学习15-运行用例命令行参数详解
前言 HttpRunner 在命令行中启动测试时,通过指定参数,可实现丰富的测试特性控制. 命令行参数CLI 使用 -h 查看相关命令行参数 hrun -h 参数名称 参数值 参数说明 -h, --h ...
- javax.persistence.PersistenceException: Unable to build entity manager factory
javax.persistence.PersistenceException: Unable to build entity manager factory at org.hibernate.jpa. ...
- Controller的激活(2)
通过VS 的Controller 创建想到创建的Controller 类型 实际上继承了抽象类System.Web.Mvc.Controller,他是ControllerBase的子类,抽象类Syst ...
- LOJ6070 基因
基因 给定一个长度为 \(n\) 的字符串 \(s\),有 \(q\) 组询问,每个询问给定 \(l,r\),询问 \(s[l..r]\) 中有多少本质不同的回文子串. 强制在线.\(n\leq 10 ...
- jmeter,badboy,jar包文件 常数吞吐量计时器?
badboy录制脚本 1.按f2 红色开始录制 URL输入:https://www.so.com/ 2.搜索框输入zxw 回车键搜索 3.选中关键字(刮例如zxw软件——>tools——> ...
- solr中特殊字符的处理
如查询的条件为:params.add("fq", "jiucaiyun_brand:Double A" ),这样是查不出带有空格的条件,需要把空格转义 if(b ...
- Atcoder Beginner Contest 138 简要题解
D - Ki 题意:给一棵有根树,节点1为根,有$Q$次操作,每次操作将一个节点及其子树的所有节点的权值加上一个值,问最后每个节点的权值. 思路:dfs序再差分一下就行了. #include < ...