前段時間用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操作了。
[java] view plaincopyPRint?/** * * 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; public JpaDaoImpl() {//very tricky here //這個被泛型化的類不能被實例化,因為實例化后this指的就是當前對象了 entityClass = (Class<E>) ((ParameterizedType) this.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()); } ...... }[java] view plaincopyprint?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); ...... }
[java] view plaincopyprint?public class UserDaoImpl extends JpaDaoImpl<User, Long>{ //No method needs } public class PrivilegeDaoImpl extends JpaDaoImpl<Privilege, String>{ //No method needs } 轉載
新聞熱點
疑難解答