码迷,mamicode.com
首页 > 其他好文 > 详细

多重继承求泛型类的类型

时间:2015-09-19 15:06:54      阅读:226      评论:0      收藏:0      [点我收藏+]

标签:

基本类:

@Repository
public class HibernateDao<T, PK extends Serializable>{
    protected Logger logger = LoggerFactory.getLogger(getClass());
    protected Class<T> entityClass;
    public HibernateDao() {
        logger.debug(String.valueOf(getEntityClass()));
    }
    /**
     * 求泛型的类类型
     * @return
     */
    protected Class<T> getEntityClass(){
        logger.debug("this.class: " + this.getClass());
        logger.debug("this.getClass().getGenericSuperclass(): "  + this.getClass().getGenericSuperclass());
        if(null == entityClass){
            entityClass = (Class<T>) ((ParameterizedType) this.getClass().getGenericSuperclass()).getActualTypeArguments()[0];
        }
        logger.debug("entityClass: " + entityClass);
        return entityClass;
    }
   ....
}

  

@Repository
public   class BaseDao<T, PK extends Serializable> extends HibernateDao<T,String> {

}

  

//应用层 处理具体的业务
@Repository
public class UserDao extends BaseDao<User, String> {

}

  继承关系很明显了,我现在BaseSrvice中实例化BaseDao:

@Service
@Transactional
public abstract class BaseService<T, PK extends Serializable> {

    protected Logger logger = LoggerFactory.getLogger(this.getClass());
    @Autowired
    private BaseDao baseDao;
    
    public BaseService() {
        printEntityClass();
    }
    
    //帮助理解
    private void printEntityClass(){
        ParameterizedType type = (ParameterizedType) this.getClass().getGenericSuperclass();
        Class c = (Class) type.getActualTypeArguments()[0];
        logger.debug(c.toString());
    }
   ...
}

  之后我在Junit中编写一个测试类【注意:应用层的测试实例】:

public class UserServiceTest extends BaseTestConfig {
    @Autowired
    private UserService userService;

    @Test
    public void testList2(){
        String id = "40283a814f7d92f7014f7d956bf50007";
        userService.get(id);
    }
}

  运行结果

技术分享

说明HibernateDao求泛型的时候,抛异常了。

修改下BaseService,将

@Autowired
private BaseDao baseDao;

 改为

@Autowired
private BaseDao<T,String> baseDao;

  再次运行:

技术分享

异常消失,注意:HibernateDao求泛型的打印输出的变化。

 

II.this.getClass().getGenericSuperclass();求出的是直接父类。如UserDao的直接父类为BaseDao而不是HibernateDao。

 

多重继承求泛型类的类型

标签:

原文地址:http://www.cnblogs.com/licqs/p/4821398.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!