关闭

java 反射机制(通过getGenericSuperclass()方法获取到父类泛型的类型)

1010人阅读 评论(0) 收藏 举报
分类:

 1. 在java中T.getClass() 或 T.class都是不合法的,因为T是泛型变量; 
    由于一个类的类型在编译期已确定,故不能在运行期得到T的实际类型;
2.获取方式是:
// 获取当前运行类泛型父类类型,即为参数化类型,有所有类型公用的高级接口Type接收!
		Type type = this.getClass().getGenericSuperclass();
		// 强转为“参数化类型”
		 //ParameterizedType参数化类型,即泛型  
		ParameterizedType pt = (ParameterizedType) type; // BaseDao<Department>
		// 获取参数化类型中,实际类型的定义
		Type[] ts = pt.getActualTypeArguments();
		// 转换
		this.clazz = (Class<T>) ts[0];


3.例子:
目录结构图为:

Person类的代码如下:

public class Person<T> {  
  
}

Student类的代码如下 :

package cn.wxz;

import java.lang.reflect.ParameterizedType;
import java.lang.reflect.Type;

public class Student extends Person<Student> {
	public static void main(String[] args) {  
		 Student stu=new Student();  
		 Class clazz=stu.getClass();  
		  System.out.println(clazz);
		  Type type = stu.getClass().getGenericSuperclass();
		  System.out.println(type);
			// 强转为“参数化类型”
			 //ParameterizedType参数化类型,即泛型  
			ParameterizedType pt = (ParameterizedType) type; // BaseDao<Department>
			// 获取参数化类型中,实际类型的定义
			Type[] ts = pt.getActualTypeArguments();
			// 转换
			 Class c= (Class) ts[0];
			 System.out.println(c);
		 }  
}

打印结果:
class cn.wxz.Person
cn.wxz.Person<cn.wxz.Student>
class cn.wxz.Student
注意:能获取到父类泛型类型,但是不能获取到类实现的接口的泛型类型:

0
1

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:12103次
    • 积分:566
    • 等级:
    • 排名:千里之外
    • 原创:43篇
    • 转载:1篇
    • 译文:0篇
    • 评论:2条
    文章分类
    最新评论