Java中类转json的基类实现
类转json的基类实现
项目地址
实现原理
使用反射获取类的属性名和属性内容。具体原理可以自己查一下资料
对一个类调用getclass().getdeclaredfields()可以获取许多信息。
通过上述方法获取到的是一个field类型的数组,这个类中有多少属性就有多少field,包括用private修饰的属性。
调用field.getname即可获得string类型的属性名,如下
for(field field : fields){ string name = field.getname(); }
有了这个属性名称还不够,还需要属性的内容,使用field.get()方法,get中放入父类
field[] fields = this.getclass().getdeclaredfields(); //遍历 for(field field : fields){ object object = field.get(this);
这样子就可以直接获取到属性内容,然后这里只需要创建一个jsonobject,把属性名和属性内容一一填入即可,最多再加一个判断内容是不是为null即可。
一个雏形方法就出来了,到这也可以简单的输出一个jsonobject的对象了。
升级版
直接使用这个方法,会发现有些参数的值怎么有点不协调,是类型加hash的形式,这样可不太好。如果是自定义类型那也就算了,当一些基础类型数组形式下输出也是这样,那可就不太好了。不过如果是list的话却没有问题
先调用gettype方法判断下数组传入时的类型,然后根据这些类型,创建对应的list,将他们填入list中,将得到的list放到jsonobject中,当然也可以直接用一个jsonobject去封装一个出来,然后放进去,但是看起来怪怪的。
如下是我自己测了一下各基本类型的type,
case "[z": //boolean case "[b"://byte case "[c"://char case "[d"://double case "[f"://float case "[j"://long case "[s"://short case "[i"://int
如果是大写的基础类型是继承自object的,这种比较好统一处理,type类型是由“[l”开头,写个if判断下就好了。把数组转为list的方法如下
/** * 数组转成list * */ private list arraytolist(object object, @notnull objecttype type){ list a = new arraylist(); switch (type){ case int: for(int i:(int[]) object){ a.add(i); } break; case boolean: for(boolean i:(boolean[]) object){ a.add(i); } break; case long: for(long i:(long[]) object){ a.add(i); } break; case float: for(float i:(float[]) object){ a.add(i); } break; case double: for(double i:(double[]) object){ a.add(i); } break; case byte: for(byte i:(byte[]) object){ a.add(i); } break; case char: for(char i:(char[]) object){ a.add(i); } break; case short: for(short i:(short[]) object){ a.add(i); } break; case object: for(object i:(object[]) object){ a.add(i); } break; default: a = null; break; } return a; }
我自己写了个枚举,当他为object时,表示是继承自object的类型处理起来就很方便了。直接把list类型的参数存入jsonobject中也不会出现hash值。
最终版
如果属性是一个自定义类怎么办呢,如果自定义类中还有一个自定义类呢。
这问题其实很简单,如果属性是自定义类怎么办,那肯定是拆他,怎么拆,他爹怎么被拆的就怎么拆他。只需要递归就可以解决。
但是如果自定义类是数组形式怎么办,之前只是列出了基础类型的type,如果是java自己的类,肯定是java开头的,所以只需如下判断
if(type.startswith("java")){ return objecttype.notlist; }else if(type.startswith("[l")){ //继承了object的数组 if(type.startswith("[ljava")) return objecttype.object; return objecttype.notbaselist; }
"[l"则是数组类型的前缀,"[ljava"则是表示java自带类型,所以剔除这两个之外就是自定义类了,如果你的类的包名正好也是java开头的,那还有个办法,把你自己的包名填入这里如“[ljava.util.”,把自己筛出来。或者直接用改成“[ljava.util.”排除所有java.util下的包也可。具体看自己操作。
这个项目的实现使用android实现的,如果是java的话就自己写写实现看看效果。具体使用可以详见github里的readme
到此这篇关于java中类转json的基类实现的文章就介绍到这了,更多相关类转json的基类内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
上一篇: 原生js实现轮播图——小肉包
下一篇: idea热部署且开启自动编译的实现方法
推荐阅读
-
Javascript中类式继承和原型式继承的实现方法和区别之处
-
C#实现将类的内容写成JSON格式字符串的方法
-
Java日期时间API系列11-----Jdk8中java.time包中的新的日期时间API类,使用java8日期时间API重写农历LunarDate
-
Java日期时间API系列9-----Jdk8中java.time包中的新的日期时间API类的Period和Duration的区别
-
MongoDB 中数据的替换方法实现 --类Replace()函数功能
-
[五]类加载机制双亲委派机制 底层代码实现原理 源码分析 java类加载双亲委派机制是如何实现的
-
Java 动态代理类的实现
-
JSP中如何通过JSP调用类(.java)中的方法
-
Java中为什么实体类需要实现Serializable序列化接口
-
实现了一个PHP5的getter/setter基类的代码