T.getClass()或者T.class都是非法的,因爲T是泛型變量。
由於一個類的類型是什麼是在編譯期處理的,故不能在運行時直接在Base裏得到T的實際類型。
/**
*@author Joshua
*@version 2011-12-15 下午02:27:43
*/
/**
* 可以在service層直接調用,也可以在DAO層擴展調用
*/
public class BaseDaoImpl<T, PK extends Serializable> implements BaseDao<T, PK>{
...
private Class<T> persistentClass;
/**
* 用於Dao層子類使用的構造函數. 通過子類的泛型定義取得對象類型
*/
@SuppressWarnings("unchecked")
public BaseDaoImpl(){
//getClass() 返回表示此 Class 所表示的實體(類、接口、基本類型或 void)的超類的 Class。
this.persistentClass=(Class<T>)getSuperClassGenricType(getClass(), 0);
}
...
/**
* 通過反射, 獲得定義Class時聲明的父類的泛型參數的類型. 如無法找到, 返回Object.class.
*
*@param clazz
* clazz The class to introspect
* @param index
* the Index of the generic ddeclaration,start from 0.
* @return the index generic declaration, or Object.class if cannot be
* determined
*/
@SuppressWarnings("unchecked")
public static Class<Object> getSuperClassGenricType(final Class clazz, final int index) {
//返回表示此 Class 所表示的實體(類、接口、基本類型或 void)的直接超類的 Type。
Type genType = clazz.getGenericSuperclass();
if (!(genType instanceof ParameterizedType)) {
return Object.class;
}
//返回表示此類型實際類型參數的 Type 對象的數組。
Type[] params = ((ParameterizedType) genType).getActualTypeArguments();
if (index >= params.length || index < 0) {
return Object.class;
}
if (!(params[index] instanceof Class)) {
return Object.class;
}
return (Class) params[index];
}