利用ParameterizedType和范型做切面编程

前段时间用hibernate的时候,看到用范型加ParameterizedType进行设计的例子,使用的比较巧。用ParameterizedType进行切面编程十分轻巧。

 

下面是一个利用ParameterizedType进行切面编程的例子:

 

例子中有一个抽象的JpaDaoImpl.java类,所以继承该类的XXXJpaDAOImpl,都对应于一个数据库表(table)。<E extends AbstractEntity, I>中的‘E’就表示该数据库表对应于Java中的entity。JpaDaoImpl类本身也implements了Dao<E, I>的接口。Dao<E, I>定义了JpaDaoImpl所需要实现的基本方法(基于数据库表的CUID方法)。

 

通过“(Class<E>) ((ParameterizedType) getClass().getGenericSuperclass()).getActualTypeArguments()[0]”,就可以得到E在实际的XXXJpaDaoImpl.java类中是什么具体的entity。得到E,我们就可以通过hibernate实现基本的CUID操作了。

/**
 * 
 * JPA implementation of DAO.
 * 
 * @param <E> entity type
 * @param <I> primary key type
 */
public class JpaDaoImpl<E extends AbstractEntity, I> extends JpaDaoSupport implements Dao<E, I> {
    protected Class<E> entityClass;

    @SuppressWarnings("unchecked")
    public JpaDaoImpl() {//very tricky here
        entityClass = (Class<E>) ((ParameterizedType) getClass().getGenericSuperclass()).getActualTypeArguments()[0];
    }

    public E create(E entity) {
        getJpaTemplate().persist(entity);
        return entity;
    }

    public void delete(E entity) {
        getJpaTemplate().remove(entity);
    }

    public void delete(I id) {
        getJpaTemplate().remove((find(id)));
    }

    public boolean exists(I id) {
        return find(id) != null;
    }

    public E find(I id) {//entityClass is used
        return getJpaTemplate().find(entityClass, id);
    }

    public E update(E entity) {
        return getJpaTemplate().merge(entity);
    }
 
    public List<E> query() {//entityClass is used
        return query("from " + entityClass.getSimpleName());
    }
......
}

 

public interface Dao<E extends AbstractEntity, I> {
    E create(E entity);

    E update(E entity);

    void delete(E entity);

    void delete(I id);

    E find(I id);

    boolean exists(I id); 

    ......
}



 

public class UserDaoImpl extends JpaDaoImpl<User, Long>{
     //No method needs
}

public class PrivilegeDaoImpl extends JpaDaoImpl<Privilege, String>{
     //No method needs
}

 

 

((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对象了..

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值