Java 反射机制
Written by
荒岛书生
on
StartTime: 2015-08-22,ModifyTime:2017-01-01
- 反射机制允许程序在运行时取得任何一个已知名称的class的内部信息,容许程序在运行时加载、探知、使用编译期间未知的class。
即Java的反射机制可以加载一个运行时才得知名称的class,获得其完整结构。比如父类中方法需要调用子类的泛型作为参数的时候。
public class Student extends Person<Student> {
public static void main(String[] args) {
Student st=new Student();
// 返回此 Object 的运行时类,得到该对象的Class。
Class clazz=st.getClass();
***//getSuperclass()获得Student该类的父类Person的
完整类名。如:class com.test.Person ***
System.out.println(clazz.getSuperclass());
***/**getGenericSuperclass()获得带有泛型的父类,方法的参数是子类Class,返回值是子类继承父类时给父类传入的泛型参数,并将其转换ParameterizedType。
该方法假定父类只有一个泛型参数,否则抛出异常。
简而言之就是获得超类的泛型参数的实际类型。
结果为com.test.Person<com.test.Student>
Type是 Java 编程语言中所有类型的公共高级接口。它们包括原始类型、参数化类型、数组类型、类型变量和基本类型。*/***
Type type=clazz.getGenericSuperclass();
//getActualTypeArguments()获取参数化类型,返回一个数组,因为获取的参数化类型可能有多个
Class c=(Class) p.getActualTypeArguments()[0];
System.out.println(c);
}
}
补充说明: if(!(type instanceof ParameterizedType)),这行代码的意思是 如果没有实现ParameterizedType接口,即不支持泛型;
java 中的instanceof 运算符是用来在运行时指出对象是否是特定类的一个实例。instanceof通过返回一个布尔值来指出,这个对象是否是这个特定类或者是它的子类的一个实例。
// 处理泛型类型
if (type instanceof ParameterizedType) {
return getGenericClass((ParameterizedType) type, i);
}
// 处理泛型擦拭对象(不理解,先放放)
else if (type instanceof TypeVariable) {
return(Class)getClass(((TypeVariable)type).getBounds()[0], 0);
}
// class本身也是type,强制转型
else {
return (Class) type;
}