其他

[软件思想] 漫谈设计模式(Design Patterns)Java篇(八)

2016-11-02 萤火虫沙龙


22、中介者模式(Mediator)

中介者模式也是用来降低类类之间的耦合的,因为如果类类之间有依赖关系的话,不利于功能的拓展和维护,因为只要修改一个对象,其它关联的对象都得进行修改。如果使用中介者模式,只需关心和Mediator类的关系,具体类类之间的关系及调度交给Mediator就行,这有点像spring容器的作用。先看看图:

User类统一接口,User1和User2分别是不同的对象,二者之间有关联,如果不采用中介者模式,则需要二者相互持有引用,这样二者的耦合度很高,为了解耦,引入了Mediator类,提供统一接口,MyMediator为其实现类,里面持有User1和User2的实例,用来实现对User1和User2的控制。这样User1和User2两个对象相互独立,他们只需要保持好和Mediator之间的关系就行,剩下的全由MyMediator类来维护!基本实现:

 

[java] view plaincopy

  1. public interface Mediator {  

  2.     public void createMediator();  

  3.     public void workAll();  

  4. }  

[java] view plaincopy

  1. public class MyMediator implements Mediator {  

  2.   

  3.     private User user1;  

  4.     private User user2;  

  5.       

  6.     public User getUser1() {  

  7.         return user1;  

  8.     }  

  9.   

  10.     public User getUser2() {  

  11.         return user2;  

  12.     }  

  13.   

  14.     @Override  

  15.     public void createMediator() {  

  16.         user1 = new User1(this);  

  17.         user2 = new User2(this);  

  18.     }  

  19.   

  20.     @Override  

  21.     public void workAll() {  

  22.         user1.work();  

  23.         user2.work();  

  24.     }  

  25. }  

[java] view plaincopy

  1. public abstract class User {  

  2.       

  3.     private Mediator mediator;  

  4.       

  5.     public Mediator getMediator(){  

  6.         return mediator;  

  7.     }  

  8.       

  9.     public User(Mediator mediator) {  

  10.         this.mediator = mediator;  

  11.     }  

  12.   

  13.     public abstract void work();  

  14. }  

[java] view plaincopy

  1. public class User1 extends User {  

  2.   

  3.     public User1(Mediator mediator){  

  4.         super(mediator);  

  5.     }  

  6.       

  7.     @Override  

  8.     public void work() {  

  9.         System.out.println("user1 exe!");  

  10.     }  

  11. }  

[java] view plaincopy

  1. public class User2 extends User {  

  2.   

  3.     public User2(Mediator mediator){  

  4.         super(mediator);  

  5.     }  

  6.       

  7.     @Override  

  8.     public void work() {  

  9.         System.out.println("user2 exe!");  

  10.     }  

  11. }  

测试类:

 

[java] view plaincopy

  1. public class Test {  

  2.   

  3.     public static void main(String[] args) {  

  4.         Mediator mediator = new MyMediator();  

  5.         mediator.createMediator();  

  6.         mediator.workAll();  

  7.     }  

  8. }  

输出:

 

 

 

 

 

 

 

user1 exe!
user2 exe!
23、解释器模式(Interpreter)
解释器模式是我们暂时的最后一讲,一般主要应用在OOP开发中的编译器的开发中,所以适用面比较窄。


Context类是一个上下文环境类,Plus和Minus分别是用来计算的实现,代码如下:

 

[java] view plaincopy

  1. public interface Expression {  

  2.     public int interpret(Context context);  

  3. }  

[java] view plaincopy

  1. public class Plus implements Expression {  

  2.   

  3.     @Override  

  4.     public int interpret(Context context) {  

  5.         return context.getNum1()+context.getNum2();  

  6.     }  

  7. }  

[java] view plaincopy

  1. public class Minus implements Expression {  

  2.   

  3.     @Override  

  4.     public int interpret(Context context) {  

  5.         return context.getNum1()-context.getNum2();  

  6.     }  

  7. }  

[java] view plaincopy

  1. public class Context {  

  2.       

  3.     private int num1;  

  4.     private int num2;  

  5.       

  6.     public Context(int num1, int num2) {  

  7.         this.num1 = num1;  

  8.         this.num2 = num2;  

  9.     }  

  10.       

  11.     public int getNum1() {  

  12.         return num1;  

  13.     }  

  14.     public void setNum1(int num1) {  

  15.         this.num1 = num1;  

  16.     }  

  17.     public int getNum2() {  

  18.         return num2;  

  19.     }  

  20.     public void setNum2(int num2) {  

  21.         this.num2 = num2;  

  22.     }  

  23.       

  24.       

  25. }  

[java] view plaincopy

  1. public class Test {  

  2.   

  3.     public static void main(String[] args) {  

  4.   

  5.         // 计算9+2-8的值  

  6.         int result = new Minus().interpret((new Context(new Plus()  

  7.                 .interpret(new Context(9, 2)), 8)));  

  8.         System.out.println(result);  

  9.     }  

  10. }  

最后输出正确的结果:3。

 

基本就这样,解释器模式用来做各种各样的解释器,如正则表达式等的解释器等等!

资源:http://download.csdn.net/detail/zhangerqing/4835830

 

原文链接:http://blog.csdn.net/zhangerqing


您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存