JAVA筹划情势之事件处理[Java编程]
本文“JAVA筹划情势之事件处理[Java编程]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
事件处理是企业利用需求办理的最主要的问题之一.J2EE通过JTA供应了完好的事件管理本领,包含多个事件性资源的管理本领.但是大部份利用都是运行在单一的事件性资源之上(一个数据库),他们并不需求全局性的事件服务.本地事件服务已然充足(比方JDBC事件管理).
本文并不谈论应当采取何种事件处理方法,主要目的是谈论若何更为文雅地计划事件服务.仅以JDBC事件处理为例.触及到的DAO,Factory,Proxy,Decorator等情势概念,请阅读相关资料.
大概你据说过,事件处理应当做在service层,大概你也正这样做,但能否知道为什么这样做?为什么不放在DAO层干事件处理.显而易见的缘由是业务层接口的每一个办法有时刻都是一个业务用例(User Case),它需求调用差别的DAO对象来完成一个业务办法.比方简单地以网上书店购书最后的肯定订单为例,业务办法首先是调用BookDAO对象(普通是通过DAO工厂产生),BookDAO判断能否还有库存余量,获得该书的价钱信息等,然后调用CustomerDAO从帐户扣除呼应的费用以及记录信息,然后是其他服务(告诉管理员等).简化业务流程大约如此:
注意,我们的例子忽视了衔接的处理,只要保证同一个线程内取的是相同的衔接便可(可用ThreadLocal实现):
首先是业务接口,针对接口,而不是针对类编程:
public interface BookStoreManager{
public boolean buyBook(String bookId,int quantity)throws SystemException;
....其他业务办法
}
接下来就是业务接口的实现类??业务对象:
public class BookStoreManagerImpl implements BookStoreManager{
public boolean buyBook(String bookId)throws SystemException{
Connection conn=ConnectionManager.getConnection();//获得数据库衔接
boolean b=false;
try{
conn.setAutoCommit(false); //撤消自动提交
BookDAO bookDAO=DAOFactory.getBookDAO();
CustomerDAO customerDAO=DAOFactory.getCustomerDAO();
//尝试从库存中取书
if(BookDAO.reduceInventory(conn,bookId,quantity)){
BigDecimal price=BookDAO.getPrice(bookId); //取价钱
//从客户帐户中扣除price*quantity的费用
b=
CustomerDAO.reduceAccount(conn,price.multiply(new BigDecimal(quantity));
....
其他业务办法,如告诉管理员,生成订单等.
...
conn.commit(); //提交事件
conn.setAutoCommit(true);
}
}catch(SQLException e){
conn.rollback(); //呈现非常,回滚事件
con.setAutoCommit(true);
e.printStackTrace();
throws new SystemException(e);
}
return b;
}
}
然后是业务代表工厂:
public final class ManagerFactory {
public static BookStoreManager getBookStoreManager() {
return new BookStoreManagerImpl();
}
}
以上是“JAVA筹划情势之事件处理[Java编程]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
本文地址: | 与您的QQ/BBS好友分享! |