泛型T的類型獲取

T.getClass()或者T.class都是非法的,因爲T是泛型變量。

由於一個類的類型是什麼是在編譯期處理的,故不能在運行時直接在Base裏得到T的實際類型。

/** 

 * 可以在service層直接調用,也可以在DAO層擴展調用 

 */ 

public class BaseDaoImpl<T> implements BaseDao<T>

 

private Class<T> persistentClass;  

/** 

* 用於Dao層子類使用的構造函數. 通過子類的泛型定義取得對象類型 

*/ 

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
     */
    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];
    }

發佈了19 篇原創文章 · 獲贊 14 · 訪問量 6萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章