共计 996 个字符,预计需要花费 3 分钟才能阅读完成。
假如你定义了一个有泛型的 Base 类,如下 BaseClass<DO, VO> 代码示例,如何在 BaseClass 中获取到子类对应的 DO、VO 的 class 对象呢?
class BaseClass<DO, VO> {
Class<DO> doClass;
Class<VO> voClass;
...
}
1. 传统方式:通过参数传递或由子类指定
// 通过参数传递
class BaseClass<DO, VO> {
//Class<?> 定义为参数,通过参数传递
public myMethod(..., Class<?> clazz){...}
}
// 由子类指定
class UserClass extends BaseClass<UserDO, UserVO> {
...{
super.doClass = UserDO.class;
super.voClass = UserVO.class;
}
}
这种方式非常简单容易理解,但会在方法 / 子类中产生冗余代码。
下面还有两种更优雅的实现代码:
2. 在 Base 类中通过 Java 反射统一获取
class BaseClass<DO, VO> {
...{Type[] types = ((ParameterizedType)getClass().getGenericSuperclass()).getActualTypeArguments();
this.doClass = (Class<DO>)types[0];
this.voClasss = (Class<VO>)types[1];
}
}
// 如果是接口获取实现类的泛型 class,需将 getGenericSuperclass() 替换成 getGenericInterfaces()
3. 在 Base 类中通过 Spring 统一获取
class BaseClass<DO, VO> {
...{ResolvableType resolvableType = ResolvableType.forClass(this.getClass()).getSuperType();
ResolvableType[] types = resolvableType.getSuperType().getGenerics();
this.doClass = (Class<DO>) types[0].resolve();
this.voClasss = (Class<VO>) types[1].resolve();}
}
Diboot – 简单高效的轻代码开发框架 (欢迎 star)
正文完