Java中類轉json的基類實現(xiàn)
類轉json的基類實現(xiàn)
項目地址
實現(xiàn)原理
使用反射獲取類的屬性名和屬性內容。具體原理可以自己查一下資料
對一個類調用getClass().getDeclaredFields()可以獲取許多信息。
通過上述方法獲取到的是一個Field類型的數(shù)組,這個類中有多少屬性就有多少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);
這樣子就可以直接獲取到屬性內容,然后這里只需要創(chuàng)建一個JsonObject,把屬性名和屬性內容一一填入即可,最多再加一個判斷內容是不是為null即可。
一個雛形方法就出來了,到這也可以簡單的輸出一個JsonObject的對象了。
升級版
直接使用這個方法,會發(fā)現(xiàn)有些參數(shù)的值怎么有點不協(xié)調,是類型加hash的形式,這樣可不太好。如果是自定義類型那也就算了,當一些基礎類型數(shù)組形式下輸出也是這樣,那可就不太好了。不過如果是list的話卻沒有問題
先調用getType方法判斷下數(shù)組傳入時的類型,然后根據(jù)這些類型,創(chuàng)建對應的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的,這種比較好統(tǒng)一處理,type類型是由“[L”開頭,寫個if判斷下就好了。把數(shù)組轉為list的方法如下
/** * 數(shù)組轉成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類型的參數(shù)存入JsonObject中也不會出現(xiàn)hash值。
最終版
如果屬性是一個自定義類怎么辦呢,如果自定義類中還有一個自定義類呢。
這問題其實很簡單,如果屬性是自定義類怎么辦,那肯定是拆他,怎么拆,他爹怎么被拆的就怎么拆他。只需要遞歸就可以解決。
但是如果自定義類是數(shù)組形式怎么辦,之前只是列出了基礎類型的type,如果是java自己的類,肯定是java開頭的,所以只需如下判斷
if(type.startsWith("java")){ return ObjectType.NOTLIST; }else if(type.startsWith("[L")){ //繼承了Object的數(shù)組 if(type.startsWith("[Ljava")) return ObjectType.OBJECT; return ObjectType.NOTBASELIST; }
"[L"則是數(shù)組類型的前綴,"[Ljava"則是表示java自帶類型,所以剔除這兩個之外就是自定義類了,如果你的類的包名正好也是java開頭的,那還有個辦法,把你自己的包名填入這里如“[Ljava.util.”,把自己篩出來?;蛘咧苯佑酶某伞癧Ljava.util.”排除所有java.util下的包也可。具體看自己操作。
這個項目的實現(xiàn)使用android實現(xiàn)的,如果是java的話就自己寫寫實現(xiàn)看看效果。具體使用可以詳見github里的readme
到此這篇關于Java中類轉json的基類實現(xiàn)的文章就介紹到這了,更多相關類轉json的基類內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Java數(shù)據(jù)結構及算法實例:三角數(shù)字
這篇文章主要介紹了Java數(shù)據(jù)結構及算法實例:三角數(shù)字,本文直接給出實現(xiàn)代碼,代碼中包含詳細注釋,需要的朋友可以參考下2015-06-06Java8新特性之StampedLock_動力節(jié)點Java學院整理
本文從synchronized、Lock到Java8新增的StampedLock進行對比分析,對Java8新特性之StampedLock相關知識感興趣的朋友一起看看吧2017-06-06SpringCloud搭建netflix-eureka微服務集群的過程詳解
這篇文章主要介紹了SpringCloud搭建netflix-eureka微服務集群的過程詳解,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-04-04解決SpringBoot ClassPathResource的大坑(FileNotFoundException)
這篇文章主要介紹了解決SpringBoot ClassPathResource的大坑(FileNotFoundException),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-06-06Java并發(fā) CompletableFuture異步編程的實現(xiàn)
這篇文章主要介紹了Java并發(fā) CompletableFuture異步編程的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-01-01