久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Java 反射類型Type的用法說(shuō)明

瀏覽:105日期:2022-08-12 13:39:32
各個(gè)方法1. 得到class的成員變量

首先得到object的class對(duì)象

然后在class對(duì)象中用getDeclaredFields()方法來(lái)獲得class的成員變量

FieldTest ft = new FieldTest();Class ftClass = ft.getClass();Field[] fields = ftClass.getDeclaredFields();2. field的函數(shù)

Field對(duì)象有很多成員方法

getName()獲取名稱。

getGenericType() 返回一個(gè)Type對(duì)象

getType() 返回Class對(duì)象

getGenericType 和getType區(qū)別:

返回類型一個(gè)是Class對(duì)象一個(gè)是Type接口。

如果屬性是泛型,getType()返回屬性的接口類型。getGenericType()還能返回參數(shù)類型。

String fieldName = field.getName();Type genericType = field.getGenericType();boolean isParameterizedType = (genericType instanceof ParameterizedType);Class fieldClazz = field.getType();String valueTypeName = genericType.getTypeName();3.獲取范型的Type和Class

獲取 范型的key和value的Type

Type[] genericTypes = ((ParameterizedType) genericType).getActualTypeArguments();Type type0 = genericTypes[0];Type type1 = genericTypes[1];

通過(guò)google的com.google.common.reflect.TypeToken.of(type1).getRawType()方法獲取map的key或者value的class類型。

Class<?> clazz = com.google.common.reflect.TypeToken.of(type1).getRawType();總代碼

class FieldTest { private String pri; protected String pro; public Map<Integer, HashMap<Integer, Float>> fcmap; public FieldTest() { } public FieldTest(String pri, String pro, String pub) {this.pri = pri;this.pro = pro; }}

package cn.hyperchain.hvm.abi;import java.lang.reflect.Array;import java.lang.reflect.Field;import java.lang.reflect.ParameterizedType;import java.lang.reflect.Type;import java.util.Arrays;import java.util.HashMap;import java.util.Map;public class Test { private static boolean checkClazzIsSpecific(Class CClazz, Class specific) {if (CClazz == specific) return true;Class[] interfaces = CClazz.getInterfaces();boolean result = false;for (Class inter : interfaces) { if (result) break; if (inter == specific) {result = true;break; } result = checkClazzIsSpecific(inter, specific);}return result; } public static void main(String args[]) {FieldTest ft = new FieldTest();Class ftClass = ft.getClass();Field[] fields = ftClass.getDeclaredFields();for (int i = 0; i < fields.length; i++) { Field field = fields[i]; String fieldName = field.getName(); Type genericType = field.getGenericType(); Class fieldClass = field.getClass(); boolean isParameterizedType = (genericType instanceof ParameterizedType); Class fieldClazz = field.getType(); String valueTypeName = genericType.getTypeName(); System.out.println(); System.out.println('-------------------------------------------------'); System.out.println(); System.out.println('fieldName: ' + fieldName); System.out.println('genericType: ' + genericType); System.out.println('fieldClazz: ' + fieldClazz); System.out.println('isParameterizedType: ' + isParameterizedType); System.out.println('valueTypeName: ' + valueTypeName); if (checkClazzIsSpecific(fieldClazz, Map.class)) {Type[] genericTypes = ((ParameterizedType) genericType).getActualTypeArguments();Type type0 = genericTypes[0];Type type1 = genericTypes[1];String type1Name = genericTypes[1].getTypeName();System.out.println('type0: ' + type0);System.out.println('type1: ' + type1);System.out.println('type1Name: ' + type1Name);System.out.println(type1 instanceof ParameterizedType);Type type3 = ((ParameterizedType)type1).getOwnerType();Class type4 = type1.getClass();//Class<?> type5 = (Class<?>) type1;System.out.println('type3: ' + type3);System.out.println('type4: ' + type4);//System.out.println(type5);Class<?> clazz = com.google.common.reflect.TypeToken.of(type1).getRawType();System.out.println('clazz: ' + clazz); }} }}class FieldTest { private String pri; protected String pro;// public Map<String, Integer> map; public Map<Integer, HashMap<Integer, Float>> fcmap; public FieldTest() { } public FieldTest(String pri, String pro, String pub) {this.pri = pri;this.pro = pro; }}class abc { private String pri; protected String pro; public String pub; public String[] string; public int[] innt; public Map<String, Integer> map; public abc() { } public abc(String pri, String pro, String pub) {this.pri = pri;this.pro = pro;this.pub = pub; }}結(jié)果:

-------------------------------------------------

fieldName: prigenericType: class java.lang.StringfieldClazz: class java.lang.StringisParameterizedType: falsevalueTypeName: java.lang.String

-------------------------------------------------

fieldName: progenericType: class java.lang.StringfieldClazz: class java.lang.StringisParameterizedType: falsevalueTypeName: java.lang.String

-------------------------------------------------

fieldName: fcmapgenericType: java.util.Map<java.lang.Integer, java.util.HashMap<java.lang.Integer, java.lang.Float>>fieldClazz: interface java.util.MapisParameterizedType: truevalueTypeName: java.util.Map<java.lang.Integer, java.util.HashMap<java.lang.Integer, java.lang.Float>>type0: class java.lang.Integertype1: java.util.HashMap<java.lang.Integer, java.lang.Float>type1Name: java.util.HashMap<java.lang.Integer, java.lang.Float>truetype3: nulltype4: class sun.reflect.generics.reflectiveObjects.ParameterizedTypeImplclazz: class java.util.HashMap

Process finished with exit code 0

補(bǔ)充:Java-使用反射獲取類型信息

Java中如何使用反射獲取類型信息?

最近寫了大量需要根據(jù)類屬性的類型反射注入值的代碼,總結(jié)了以下常用的反射技巧:

一個(gè)簡(jiǎn)單類的例子

在這個(gè)類中,有普通的String類型,有數(shù)組類型,有帶泛型的List類型,有嵌套List類型,以及有多個(gè)泛型參數(shù)的簡(jiǎn)單類,這個(gè)類將作為我們后面的內(nèi)容的基礎(chǔ)。我們這一次博客解析如何使用反射獲取到不同屬性的類型值。

public class Some{ private String name; private Integer[] numbers; private List<String> list; private List<List<Double>> matrix; private Map<String,Class> map; //ignore getter and setter}分析如何獲取不同屬性的類型1、普通類型

普通類型的變量直接field.getType()即可以獲取到他們的類型

public void queryNameType() throws NoSuchFieldException { Field field = Some.class.getDeclaredField('name'); Class<?> type = field.getType(); assertEquals(type,String.class);}2、數(shù)組類型

數(shù)組類型不像其他的類型可以通過(guò)isAssignableFrom()函數(shù)來(lái)進(jìn)行判斷,他需要使用isArray() 來(lái)判斷該type是否是一個(gè)數(shù)組類型,然后使用getComponentType() 獲取他的元素的類型

public void queryArrayType() throws NoSuchFieldException { Field field = Some.class.getDeclaredField('numbers'); Class<?> type = field.getType(); //一般來(lái)說(shuō),判斷是否是某種類型是可以使用isAssignableFrom // 判斷是否是數(shù)組類型比較特殊,要使用isArray()這個(gè)函數(shù) if (type.isArray()){//獲得數(shù)組的類型,使用getComponentType()這個(gè)方法Class<?> componentType = type.getComponentType();assertEquals(componentType,Integer.class); } else{throw new IllegalStateException(); }}3、帶泛型的類型

帶泛型的類型就是類似于List<String>這樣的類型,我們現(xiàn)在的任務(wù)就是獲取到String這個(gè)類型。

ParameterizedType表示參數(shù)化的類型,例如Collection這樣的類型。我們可以通過(guò)getGenericType()方法獲得該子類,當(dāng)你的類型帶有參數(shù)的時(shí)候就會(huì)返回ParameterizedType,否則會(huì)返回普通的類型(class)

那么具體是怎么操作的呢?

以獲得List<T>的類型為例子

public void getListType() throws NoSuchFieldException { Field field = Some.class.getDeclaredField('list'); //如果類似于List<String>這樣的類型就是一種GenericType //注意這是一種Type類型 Type type = field.getGenericType(); if (type instanceof ParameterizedType){//泛型參數(shù)類型ParameterizedType parameterizedType = (ParameterizedType)type;Type[] actualTypes = parameterizedType.getActualTypeArguments();//因?yàn)長(zhǎng)ist<String>獲得第一個(gè)泛型參數(shù),因?yàn)橹挥幸粋€(gè),我們?nèi)〉谝粋€(gè)//如果我們有多個(gè)泛型參數(shù),我們可以根據(jù)順序取不同的泛型參數(shù)assertEquals(actualTypes[0],String.class);//如果獲得List這個(gè)原始類型呢?assertEquals(parameterizedType.getRawType(),List.class); }else{throw new IllegalStateException(); }}4、復(fù)雜的嵌套類型

假如是List<List<String>> 如何獲得最里面的類型呢?

例子如下

public void getSubListType() throws NoSuchFieldException { //思考一下,如果我們有一個(gè)嵌套List,我們想拿到嵌套在最里面的類型,那么我們可以這么做呢? //其實(shí)我們可以使用遞歸的思想去獲得最里面的類型 Field field = Some.class.getDeclaredField('matrix'); assertEquals(getBaseType(field.getGenericType()),Double.class); } public static Type getBaseType(Type genericReturnType){ Objects.requireNonNull(genericReturnType); if (genericReturnType instanceof ParameterizedType && List.class.isAssignableFrom((Class)(((ParameterizedType) genericReturnType).getRawType()))){ Type[] actualTypeArguments = ((ParameterizedType)genericReturnType).getActualTypeArguments(); Type type = actualTypeArguments[0]; return getBaseType(type); }else{ return genericReturnType; } }5、多個(gè)泛型參數(shù)

與第三個(gè)例子相似,只需要使用actualTypes數(shù)組按順序取即可

例子如下

public void getMapType() throws NoSuchFieldException { Field field = Some.class.getDeclaredField('map'); Type type = field.getGenericType(); if (type instanceof ParameterizedType){ParameterizedType parameterizedType = (ParameterizedType)type;Type[] actualTypes = parameterizedType.getActualTypeArguments();assertEquals(actualTypes[0],String.class);assertEquals(actualTypes[1],Class.class); }else{throw new IllegalStateException(); }}總結(jié)

以上總結(jié)了幾種常用的使用反射獲取屬性類型的例子,稍加改造就可以寫自己的工具類了。希望對(duì)大家有幫助^_^

標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 天天拍天天草 | 色婷婷网 | 91精品国产一区二区三区蜜臀 | 欧美精品久久久久久久久老牛影院 | 国产美女在线观看 | √新版天堂资源在线资源 | 欧美日韩在线免费 | 久久兔费看a级 | 国产视频久久久久 | 操操日| 午夜a级理论片915影院 | 久久高清 | 国产精品一区二区在线 | 欧美一区永久视频免费观看 | 亚洲福利影院 | 日韩一区二区免费视频 | 国产超碰人人爽人人做人人爱 | 精品二三区 | 日韩成人影院 | 婷婷久久综合九色综合绿巨人 | 99久久久国产精品 | 久久久久国产精品www | 久草视频首页 | 日韩综合 | 久久久久久国产精品mv | 天天干天天爽 | 亚洲视频一区二区三区 | 久久国内 | 999视频在线免费观看 | 欧美国产精品一区 | 青青草免费在线视频 | 99久久视频 | 亚洲精选一区 | 亚洲毛片 | 国产精品96久久久久久久 | 婷婷精品 | 久热中文在线 | xxxx欧美 | 精品国产一区二区三区高潮视 | 四色成人av永久网址 | 亚洲品质自拍视频网站 |