如何在父类中获取子类泛型的Class

本文介绍三种优雅的方法,在泛型Base类中获取子类对应的DO、VO类对象。第一种是在子类中指定,第二种是通过Java反射在Base类中统一获取,第三种是通过Spring框架在Base类中获取。这些方法避免了冗余代码,提高了代码的可读性和维护性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

假如你定义了一个有泛型的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)

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值