java获取泛型class_Java 得到泛型中得到T.class

Class entityClass = (Class ) ((ParameterizedType) getClass().getGenericSuperclass()).getActualTypeArguments()[0];

getGenericInterfaces()和getGenericSuperclass()

getInterfaces()和getSuperclass()

先来看看这两个方法都是干什么用的:

1. public Type getGenericSuperclass()

用来返回表示当前Class 所表示的实体(类、接口、基本类型或 void)的直接超类的Type。如果这个直接超类是参数化类型的,则返回的Type对象必须明确反映在源代码中声明时使用的类型。比如:

importjava.lang.reflect.ParameterizedType;public class GT1 extends GT2{public static voidmain(String[] args) {

System.out.println(((ParameterizedType)newGT1().getClass().getGenericSuperclass()));

}

}

则输出结果即为:

GT2

如果此Class代表的是Object 类、接口、基本类型或 void,则返回 null。。如果此对象表示一个数组类,则返回表示 Object 类的 Class 对象。

2. public Type[] getGenericInterfaces()

与上面那个方法类似,只不过Java的类可以实现多个接口,所以返回的Type必须用数组来存储。

以上两个方法返回的都是Type对象或数组,在我们的这个话题中,Class都是代表的参数化类型,因此可以将Type对象Cast成ParameterizedType对象。而 ParameterizedType对象有一个方法, getActualTypeArguments()。

public Type[] getActualTypeArguments()

用来返回一个Type对象数组,这个数组代表着这个Type声明中实际使用的类型。接着使用上面的例子:

importjava.lang.reflect.ParameterizedType;public class GT1 extends GT2{public static voidmain(String[] args) {

System.out.println(((ParameterizedType)new GT1().getClass().getGenericSuperclass()).getActualTypeArguments()[0]);

}

}

这次的显示结果将是:class java.lang.Integer

因此,我们可以通过继承+反射的方法,来的到T.class。

需要说明的是,江南白衣使用的方法是将关键语句

Class   entityClass  =  (Class  ) ((ParameterizedType) getClass().getGenericSuperclass()).getActualTypeArguments()[ 0 ];

放在了超类,也就是声明泛型的那个类的构造方法中。这样一来,子类在继承具有泛型的超类时,会自动调用超类的构造方法。在此超类的构造方法中,调用的getClass返回的是子类的Class类型(与通常的重写机制有悖,呵呵,有待深究,但测试结果确是如此),则在子类中就无需再显式地使用getGenericInterfaces()和getGenericSuperclass()等方法了。

接着,再使用(Class)对 getActualTypeArguments()返回的元素做casting,即可得到所谓的T.class。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java获取泛型T的Class通常有两种方式。 第一种方式是使用泛型类的getClass()方法来获取泛型T的Class信息。这种方式的前提是必须要创建泛型对象。具体实现方法如下: ``` public class GenericClass<T>{ public Class<T> getGenericClass() { Class<T> cls = (Class<T>) ((ParameterizedType)getClass().getGenericSuperclass()).getActualTypeArguments()[0]; return cls; } } public class Main { public static void main(String[] args) { GenericClass<String> gc = new GenericClass<String>(){}; System.out.println(gc.getGenericClass()); } } ``` 第二种方式是使用TypeReference类。这是由Jackson库提供的一个工具类,可以避免在运行时由于泛型擦除而导致的Class信息丢失的问题。具体实现方法如下: ``` public abstract class TypeReference<T> { private final Type type; protected TypeReference() { Type superClass = getClass().getGenericSuperclass(); if (superClass instanceof Class<?>) { throw new IllegalArgumentException("Internal error: TypeReference constructed without actual type information"); } type = ((ParameterizedType) superClass).getActualTypeArguments()[0]; } public Type getType() { return type; } } public class Main { public static void main(String[] args) { TypeReference<List<String>> typeReference = new TypeReference<List<String>>() {}; System.out.println(typeReference.getType()); } } ``` 无论是哪种方式,获取泛型T的Class都可以方便地进行类型检查和类型转换操作。但需要注意的是,在获取泛型T的Class时,必须要保证T已经被实例化。如果T没有被实例化,则获取Class信息可能不准确,无法保证正确性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值