<!转载!——>
前段时间用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); ...... }