本方法是在使用封装通用代码 或者封装Base类是需要用到
收到参数xxx xxx.class , 以前使用object 和 ? extends Object
使用此方法是收到参数T t.class() 使用下面代码替代
重要
//这是在封装BaseMongoDbDao时用到的代码 点击查看完整代码
public static BaseMongoDaoImpl mongodbUtils;
public Class c;
@PostConstruct
public void init() {
mongodbUtils = this;
mongodbUtils.mongoTemplate = this.mongoTemplate;
c= (Class) ((ParameterizedType) getClass().getGenericSuperclass()).getActualTypeArguments()[0];
}
getClass().getGenericSuperclass()返回表示此 Class 所表示的实体(类、接口、基本类型或 void)的直接超类的 Type
然后将其转换ParameterizedType。。
getActualTypeArguments()返回表示此类型实际类型参数的 Type 对象的数组。
[0]就是这个数组中第一个了。。
简而言之就是获得超类的泛型参数的实际类型。。
比如
超类
public class GenericDAO<T> {
private Class<T> entityClass;
protected GenericDAO() {
Type type = getClass().getGenericSuperclass();
Type trueType = ((ParameterizedType) type).getActualTypeArguments()[0];
this.entityClass = (Class<T>) trueType;
}
}
子类
public class OptionManager extends GenericDAO<MSGC_OPTION> {
}
测试类
public class OracleTest {
public static void main(String[] args) throws Exception {
OptionManager manager = new OptionManager();
}
}
这样在你new OptionManager();以后
超类里的entityClass就是子类那里的public class OptionManager extends GenericDAO<MSGC_OPTION> 里面的MSGC_OPTION所对应的class对象了…
本方法用于封装通用代码或Base类,接收参数T t.class()。通过`getClass().getGenericSuperclass()`获取超类的直接超类型,再转换为ParameterizedType,调用`getActualTypeArguments()[0]`得到超类的泛型参数实际类型。例如在`OptionManager`类中,能获取到`GenericDAO<MSGC_OPTION>`中的`MSGC_OPTION`类对象。

1221

被折叠的 条评论
为什么被折叠?



