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