[转载]计数代理模式(Countingnbsp;Proxynbsp;Pattern)

计数代理模式(Countingnbsp;Proxynbsp;Pattern)

第26章 计数代理模式(Counting Proxy Pattern)


描述:

计数代理 模式在客户对象调用服务提供者对象上方法的前后执行诸如日志(logging)和计数(counting)一系列附加功能时很有用。计数代理模式建议把这 些附加功能封装在一个单独的对象,这个对象就是指计数代理对象,而不是把这些附加的功能实现放到服务提供者的内部。良好的对象设计的一个特征就是对象要专 注于提供特定的功能。换句话说,理想的对象不应该做各种不相干的事情。把诸如日志(logging)和计数(counting)等类似的功能封装为一个单 独的对象,而让服务提供者对象仅提供它自己的特定功能。也就是说,只允许服务提供者对象执行定义良好、特定的任务。
计数代理被设计成可以被客户访问的与服务提供者具有相同接口的对象。客户对象不是直接访问服务提供者,而是调用计数代理对象上的方法,计数代理执行必要的纪录日志(logging)和计数(counting)功能后,再把方法调用传递给服务提供着对象。如图26.1
26.1.bmp
Figure 26.1: Generic Class Association When the Counting Proxy Pattern Is Applied
下面的例子说明了如何在应用程序中利用计数代理。
例子

让我们设计一个Order类,类层次如图26.2,OrderIF接口声明了getAllOrders读取数据库中所有订单的简单方法。

26.2.bmp
Figure 26.2: Order Class Hierarchy
  1. public interface OrderIF {
  2. public Vector getAllOrders();
  3. }

作为getAllOrders方法实现的一部分,Order类实用了FileUtil工具类从order.txt文件中读取订单项。
  1. public class Order implements OrderIF {
  2. public Vector getAllOrders() {
  3. FileUtil fileUtil = new FileUtil();
  4. Vector v = fileUtil.fileToVector("orders.txt");
  5. return v;
  6. }
  7. }

让我们假定在调用getAllOrders()时,需要把取数据文件所花费的时间和记录条数要记录的log日志文件中。
这个附加的功能可以设计一个单独的OrderProxy类来实现,它与真实对象Order一样实现OrderIF接口。这样保证了OrderProxy对象提供给客户与真实对象Order一样的接口。如图26.3
26.3.bmp
Figure 26.3: Order Class Hierarchy with the Counting Proxy
  1. public class OrderProxy implements OrderIF {
  2. private int counter = 0;
  3. public Vector getAllOrders() {
  4. Order order = new Order();
  5. counter++;
  6. long t1 = System.currentTimeMillis ();
  7. Vector v = order.getAllOrders();
  8. long t2 = System.currentTimeMillis();
  9. long timeDiff = t2 ? t1;
  10. String msg =
  11. "Iteration=" + counter + "::Time=" + timeDiff +
  12. "ms";
  13. //log the message
  14. FileUtil fileUtil = new FileUtil();
  15. fileUtil.writeToFile("log.txt”,msg, true, true);
  16. return v;
  17. }
  18. }

客户对象MainApp就想调用真实对象Order一样调用OrderProxy对象上的getAllOrders()方法,OrderProxy对象传 递这个调用给真实对象Order,计算读取所有订单所花费的时间并使用FileUtil帮助类将其纪录的log日志文件中。在这个过程中, OrderProxy扮演者计数代理的角色。
  1. public class MainApp {
  2. public static void main(String[] args) {
  3. OrderIF order = new OrderProxy();
  4. Vector v = order.getAllOrders();
  5. v = order.getAllOrders();
  6. v = order.getAllOrders();
  7. v = order.getAllOrders();
  8. }
  9. }

附件为原文和代码!
附件:Chapter_26.doc(93K) 附件:30.rar(6K)

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/374079/viewspace-132291/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/374079/viewspace-132291/

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值