JAVA一种获得泛型类泛型参数Class对象的方法_什么乱七八糟的-CSDN博客

我在最近的开发中遇到这样一种情形,就是有一个类需要使用泛型进行实现,但是又同时需要用到泛型的Class对象。然而由于Java泛型擦除没办法直接得到泛型参数的Class对象。本已打算放弃,但是在编写其它代码的过程中,无意间从jackson的TypeReference文件得到线索。找到了通过泛型类的特化子类获得泛型参数类型Class的方法。通过代码和注释示例如下:

package com.tools; import java.lang.reflect.ParameterizedType;import java.lang.reflect.Type; /** * 关于方法ParameterizedType.getActualTypeArguments()的使用: * 1、继承泛型类(包括抽象类和实体类)产生子类,并且必须指定实际泛型参数,也就是产生一个特化子类。 * 2、对于该特化子类其泛型父类其实是一个参数化后的特化类,可通过调用该特化子类的Class对象 *    的getGenericSuperclass()方法得到其参数化父类。得到一个ParameterizedType对象。之后即可通 *    过调用其参数化父类对象的ParameterizedType.getActualTypeArguments()得到实际的类型参数并可 *    转换为类型参数的Class对象。 * 3、假设出于接口统一等目的,在泛型类当中编写了一个方法用于获取泛型参数的Class对象,并在该方法里 *    调用了getActualTypeArguments()方法。那么这样编写是没有问题的。但是不能对该泛型类的直接实例 *    化对象调用该方法,但可以对该泛型类的特化子类实例化对象调用该方法。这是因为只有该泛型类的特化 *    子类才有参数化泛型父类。 * 4、泛型接口GenericInterface的泛型参数Class对象也可以通过类似的方法得到。因为他们的产生原理都是 *    类似的。所以也可在特化子类的Class对象调用getGenericInterfaces()得到参数化泛型接口对象。 * 5、所有内容是从Jackson-core版本2.5.3的类com.fasterxml.jackson.core.type.TypeReference<T>获得。 * */public class GenericParameterTest {  public static void main(String[] args) {  // TODO Auto-generated method stub  //1、泛型类的直接实例化对象,不能调用getType(),即使是带参实例化。  A<String> a=new A<String>();  try{   System.out.println(a.getType());  }catch(Throwable e){   System.out.println("泛型类直接实例化对象调用时会爆异常");  }    //2、泛型类的子类实例化对象,可以调用getType(),即使是通过匿名内部类产生的子类对象。  A<String> a1=new A<String>() {     };    System.out.println("子类实例化外部调用:"+a1.getType());    //3、子类内部也是可以调用的  new A<String>(){   void fuck() {    //在子类的方法中调用也可以获得type    System.out.println("子类内部:"+getType());   }  }.fuck(); } class A<T> { Class<T> getType() {  Type superClass = getClass().getGenericSuperclass();  return (Class<T>) ((ParameterizedType) superClass).getActualTypeArguments()[0]; }}

原网址: 访问
创建于: 2021-08-24 11:19:21
目录: default
标签: 无

请先后发表评论
  • 最新评论
  • 总共0条评论