T.getClass()或者T.class都是非法的,因为T是泛型变量。
由于一个类的类型是什么是在编译期处理的,故不能在运行时直接在Base里得到T的实际类型。
public abstract class BaseDaoImpl<T extends Serializable> implements BaseDao<T> {
/**
*BaseDaoImpl<T>的构造函数中的 this 指的是子类的实例。
*this.getClass()获取子类的真实类型;
*c.getGenericSuperclass(); 获取泛型父类
*t.getActualTypeArguments(); 通过该泛型父类来获取真实的类型参数的数组;也就是获取泛型父类的尖括号里面的参数<T>,
*因为泛型的尖括号是可以有多个参数的,所以该方法返回的是一个数组。
*p[0](既:t.getActualTypeArguments()[0]); 获取该数组的第一个值。因为我们知道在该例子中BaseDaoImpl<T>只有一个参数T。所以我们只需要获取第一个值就可以了。
*/
@SuppressWarnings("unchecked")
private Class getSuperClassGenricType(final Class clazz) {
final int index = 0;
Type genType = clazz.getGenericSuperclass();
if (genType instanceof ParameterizedType) {
Type[] params = ((ParameterizedType) genType).getActualTypeArguments();
if (index >= 0 && index < params.length) {
if (params[index] instanceof Class)
return (Class) params[index];
}
}
return Object.class;
}
}