欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Java中类转json的基类实现

程序员文章站 2022-04-12 19:10:26
类转json的基类实现项目地址github地址实现原理使用反射获取类的属性名和属性内容。具体原理可以自己查一下资料对一个类调用getclass().getdeclaredfields()可以获取许多信...

类转json的基类实现

项目地址

github地址

实现原理

使用反射获取类的属性名和属性内容。具体原理可以自己查一下资料

对一个类调用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的基类内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

相关标签: java json 基类