getGenericSuperclass的用法

原文链接

一、getGenericSuperclass()和getActualTypeArguments()基本用法:

import java.lang.reflect.ParameterizedType;
public class TT extends TT2<Integer> {

public static void main(String[] args) {

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

}

}
//output:class java.lang.Integer
说明: getGenericSuperclass() 通过反射获取当前类表示的实体(类,接口,基本类型或void)的直接父类的Type,getActualTypeArguments()返回参数数组。
这段代码是这个意思,看是不是支持泛型的,Type type = this.getClass().getGenericSuperclass(); 是得到这个类的得到泛型父类 ,if(!(type instanceof ParameterizedType)),这行代码的意思是
如果没有实现ParameterizedType接口,即不支持泛型;Type[] params = ((ParameterizedType) genType).getActualTypeArguments();这行代码的意思是,如果支持泛型,返回表示此类型实际类型参数的Type对象的数组,数组里放的都是对应类型的Class,因为可能有多个,所以是数组。
后面的应该你很容易就看懂了。
超类就是父类了,
getActualTypeArguments()就是获取泛型参数的类型

比如Test<T>,最后就得到T类型

 

二、泛型 DAO  模拟
BaseDaoImpl类:
package com.mrlun.oa.test;
import java.lang.reflect.ParameterizedType;
@SuppressWarnings("unchecked")
public  class BaseDaoImpl<T> {
private  Class clazz;

public BaseDaoImpl() {
ParameterizedType pt = (ParameterizedType) this.getClass()
.getGenericSuperclass();
this.clazz = ( Class) pt.getActualTypeArguments()[0];
System.out.println("Type为: " + clazz.getSimpleName());
}
public void save() {
System.out.println("Type为: " + clazz.getSimpleName());
}

}
UserDao类:
package com.mrlun.oa.test;

public  class UserDao extends BaseDaoImpl<Users>{

}
测试类:
package com.mrlun.oa.test;

public  class Test{
public static void main(String[] args) {
UserDao userdao=new UserDao();
userdao.save();
}
}
//output:
Type为: Users(new 子类时会调用父类的默认的构造方法)
Type为: Users
这时,我们就可以使用泛型来简化DAO的操作,省去了写N多有重复的方法的DAO的时间

猜你喜欢

转载自blog.csdn.net/songyuequan/article/details/51094216
今日推荐