时间:2021-05-19
一、概述
1.目标:要在Tank的move()方法做时间代理及日志代理(可以设想以后还要增加很多代理处理),且代理间的顺序可活更换
2.思路:
(1)聚合:代理类聚合了被代理类,且代理类及被代理类都实现了movable接口,则可实现灵活多变,具体看代码
(2)继承:继承不够灵活,随着功能需求增多,继承体系会非常臃肿。具体看代码
二、代码
1.Movable.java
2.Tank.java
3.TankTimeProxy.java
4.TankLogProxy.java
5.Tank2Time.java
6.Tank3Log.java
7.Client.java
1.Movable.java
public interface Movable { public void move(); }2.Tank.java
import java.util.Random;public class Tank implements Movable { @Override public void move() { System.out.println("Tank moving......."); try { Thread.sleep(new Random().nextInt(5000)); } catch (InterruptedException e) { e.printStackTrace(); } }}3.TankTimeProxy.java
public class TankTimeProxy implements Movable { Movable m; public TankTimeProxy(Movable m) { this.m = m; } @Override public void move() { System.out.println("Time Proxy start..........."); long start = System.currentTimeMillis(); m.move(); long end = System.currentTimeMillis(); System.out.println("花费时间:"+(end - start)); System.out.println("Time Proxy end..........."); }}4.TankLogProxy.java
public class TankLogProxy implements Movable { Movable m; public TankLogProxy(Movable m) { this.m = m; } @Override public void move() { System.out.println("Log Proxy start..........."); m.move(); System.out.println("Log Proxy end..........."); }}5.Tank2Time.java
public class Tank2Time extends Tank { public void move(){ System.out.println("Tank2 time start..........."); long start = System.currentTimeMillis(); super.move(); long end = System.currentTimeMillis(); System.out.println("花费时间:"+(end - start)); System.out.println("Tank2 time end..........."); }}6.Tank3Log.java
public class Tank3Log extends Tank2Time { public void move(){ System.out.println("Tank3Log start..........."); super.move(); System.out.println("Tank3Log end..........."); }}7.Client.java
public class Client { @Test public void testProxy(){ Tank t = new Tank(); Movable m; //一、聚合的方式(较灵活,因为实现了接口) //1.1聚合方式的代理,先日志代理,后时间代理 TankTimeProxy ttp1 = new TankTimeProxy(t); TankLogProxy tlp1 = new TankLogProxy(ttp1); m = tlp1; m.move(); System.out.println("\n==============================分隔线==========================\n"); //1.2聚合方式的代理,先时间代理,后日志代理(可以灵活切换顺序) TankLogProxy tlp2 = new TankLogProxy(t); TankTimeProxy ttp2 = new TankTimeProxy(tlp2); m = ttp2; m.move(); System.out.println("\n==============================分隔线==========================\n"); //二、继承的方式 //2.1代理时间 Tank2Time t2 = new Tank2Time(); t2.move(); System.out.println("\n==============================分隔线==========================\n"); //2.2先代理日志,后时间,不能灵活切换 Tank3Log t3 = new Tank3Log(); t3.move(); }}三、运行结果
因为每个代理都实现了同一movable接口,代理和被代理对象之间都可以相互灵活转换,以实现代理功能之间的灵活叠加组合。
以上这篇java设计模式—静态代理模式(聚合与继承方式对比)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了java设计模式之静态代理模式。分享给大家供大家参考,具体如下:代理模式,可以通过代理可以在原来的基础上附加一些其他的操作。静态代理模式相对比较简
正文关于Java中的动态代理,我们首先需要了解的是一种常用的设计模式--代理模式,而对于代理,根据创建代理类的时间点,又可以分为静态代理和动态代理。静态代理1、
一、代理模式代理模式是常用的java设计模式,特征是代理类与委托类有同样的接口,代理类主要负责为委托类预处理消息、过滤消息、把消息转发给委托类,以及事后处理消息
和大家一起聊一聊java代理模式1、静态代理1.1静态代理的代理类和和被代理的类都要维护一个共同的接口。publicinterfaceIUserDao{void
本文实例讲述了Java设计模式之静态工厂模式。分享给大家供大家参考,具体如下:静态工厂模式(staticfactory)也叫简单工厂模式。涉及到3个角色:工厂类