中介者设计模式是一种很常见的设计模式,当中我们最为熟悉的就是我们的MVC框架。当中的C作为控制器就是一个详细的中介者,它的作用是把业务逻辑(Model),和视图(Viwe)隔离开来。使M V协调工作,把M执行的的结果和V代表的视图融合成一个前端能够展示的页面,降低M 和V的依赖关系,如今MVC框架也是一个很成熟的框架。这也是中介者模式长处的一个体现。

以下是我在书上面看过的一个样例,它的大概意思就是进销存:

如图所看到的:

通过中介者之后使得各个类之间不用相互打搅。有什么须要交互的直接通知中介者。让中介者来统一解决。

以下我通过上面这个样例用代码模拟出来,里面事实上也就解说了,中介者所起到的作用:

1:抽象中介者:

package mediator;
//这是一个抽象中介者,
public abstract class AbstractorMediator {
protected Purchase purchase;
protected Sale sale;
protected Stock stock;
//构造函数
public AbstractorMediator(){
purchase = new Purchase(this);
sale = new Sale(this);
stock = new Stock(this);
}
//中介者中最重要的方法 叫做事件方法,处理多个对象之间的关系。
public abstract void execute(String str,Object...objects);
}
package mediator;
/**
*这是抽象中介者的详细实现类,里面当中定义了多个私有方法,其目的就是为了处理各个对象之间的依赖关系。 * @author Administrator
*
*/
public class Mediator extends AbstractorMediator{ @Override
public void execute(String str, Object... objects) {
//中介者中最重要的方法
if(str.equals("purchase.buy")){
this.buyComputer((Integer)objects[0]);
}else if(str.equals("sale.sell")){
this.sellComputer((Integer)objects[0]);
}else if(str.equals("sell.offSell")){
this.offSell();
}else if(str.equals("stock.clear")){
this.clearStock();
}
} private void buyComputer(int number){
int saleStatus = super.sale.getSaleStatus();
if(saleStatus>80){
System.out.println("採购电脑的 "+ number+" 台");
super.stock.increase(number);
}else{
int buyNumber = number/2;
System.out.println("採购IBM电脑: "+ buyNumber+" 台");
}
} private void sellComputer(int number){
if(super.stock.getStockNumber()<number){
super.purchase.buyIBMcomputer(number);
}
super.stock.decrease(number);
} private void offSell(){
System.out.println("折价销售电脑 "+ stock.getStockNumber());
} private void clearStock(){
super.sale.offSale();
super.purchase.refuseBuyIBMcomputer();
} }
package mediator;
/**
* 这个是同事类的抽象
* @author Administrator
*
*/
public class AbstractorColleague {
protected AbstractorMediator mediator;
public AbstractorColleague(AbstractorMediator _mediator){
this.mediator = _mediator;
}
}
package mediator;
//同事类的详细实现
public class Purchase extends AbstractorColleague{ public Purchase(AbstractorMediator _mediator) {
super(_mediator);
}
//採购电脑 public void buyIBMcomputer(int number){
super.mediator.execute("buy computer", number);
} public void refuseBuyIBMcomputer(){
System.out.println("dont buy it");
} }
package mediator;

import java.util.Random;

public class Sale extends AbstractorColleague{

	public Sale(AbstractorMediator _mediator) {
super(_mediator);
}
//销售电脑
public void sellIBMComputer(int number){
super.mediator.execute("sale.sell", number);
System.out.println("销售情况 "+ number +" 台");
} public int getSaleStatus(){
Random rand = new Random(System.currentTimeMillis());
int saleStatus = rand.nextInt(100);
System.out.println("电脑的销售情况为:"+saleStatus);
return saleStatus;
}
//折扣处理
public void offSale(){
super.mediator.execute("sale.offSell");
}
}
package mediator;

public class Stock extends AbstractorColleague{

	public Stock(AbstractorMediator _mediator) {
super(_mediator);
} private static int COMPUTER_NUM = 100;
//添加库存数量
public void increase(int number){
COMPUTER_NUM = COMPUTER_NUM + number;
System.out.println("库存数量为:"+COMPUTER_NUM);
}
//降低库存数量
public void decrease(int number){
COMPUTER_NUM = COMPUTER_NUM - number;
System.out.println("库存数量为:"+COMPUTER_NUM);
}
//获得库存数量
public int getStockNumber(){
return COMPUTER_NUM;
}
//库存压力大了就通知 销售人员尽快销售
public void clearStock(){
System.out.println("清理存活数量为:"+COMPUTER_NUM);
super.mediator.execute("stock.clear");
}
}
package mediator;
//模拟client的測试类,(能够通过这个类来细致研究一下中介者设计模式的详细运行流程)
public class Client {
public static void main(String[] args) {
AbstractorMediator mediator = new Mediator();
System.out.println("採购人呀U呢採购电脑 ");
Purchase purchase = new Purchase(mediator);
purchase.buyIBMcomputer(100); System.out.println("销售人员销售电脑");
Sale sale = new Sale(mediator);
sale.sellIBMComputer(1); System.out.println("库房里人员清理库存");
Stock stock = new Stock(mediator);
stock.clearStock();
}
}

中介者对象的定义:用一个中介对象封装一系列对象交互。使各个对象不须要显示的相互作用,从而使其耦合松散;并且能够独立改变他们之间的交互。

当中主要有三部分构成:

1:抽象中介者角色:它统一的定义一个接口,用于各个同事之间的通信。

2:详细中介者角色:协调各个同事角色实现协调行为,因此它必须依赖各个同事角色。

3:同事角色:每个同事角色都知道中介者角色,并且与其它同事角色进行通信的时间必须通过中介者协调。一般同事角色有两种行为,一种是自发的行为。另一种是必须依赖与中介者的行为  这是依赖方法。

(详细可通过读代码)有时间我会总结一个很通用简单的代码,放到这上面。该歇息了,明天再说吧。

Java中介者设计模式的更多相关文章

  1. java 23种设计模式,一般情况下,常用的有哪些? 转载

    原址:http://wangle.iteye.com/blog/196972 工厂模式, 工厂方法模式,单例模式, 外观(Facade)模式, 观察者(Observer)模式,桥接(Bridge)模式 ...

  2. Java中单态设计模式

    Java中单态设计模式 2011-09-23 16:38:46|  分类: Java |  标签:technology!  |举报|字号 订阅     此博文是转自新浪博客中一名叫做"俊俊的 ...

  3. 【转】java io 流 设计模式

    知识点:什么是装饰模式: http://wenku.baidu.com/view/ad4eac9f51e79b896802263b.html(原理讲的很清楚) http://wenku.baidu.c ...

  4. JDK/Java里的设计模式

    JDK/Java里的设计模式

  5. Java江湖之设计模式

    Java江湖之设计模式 ps:最近在学习设计模式,感觉这个是个装逼神器呀,就跟武功一样.     某日,senior同学看见rookie同学在练功.     问,"你练得什么武功?" ...

  6. java里面的设计模式

    文章目录 Creational(创建模式) 1. Abstract factory: 2. Builder: 3. Factory: 4. Prototype: 5. Singleton: 6. Ch ...

  7. Java单例设计模式的实现

    1. 单例设计模式的定义 单例设计模式确保类只有一个实例对象,类本身负责创建自己的对象并向整个系统提供这个实例.在访问这个对象的时候,访问者可以直接获取到这个唯一对象而不必由访问者进行实例化. 单例设 ...

  8. Java进阶篇设计模式之十 ---- 访问者模式和中介者模式

    前言 在上一篇中我们学习了行为型模式的解释器模式(Interpreter Pattern)和迭代器模式(Iterator Pattern).本篇则来学习下行为型模式的两个模式,访问者模式(Visito ...

  9. Java 23种设计模式

    转自: http://zz563143188.iteye.com/blog/1847029 ; i<count; i++){ list.add(new MailSender()); } } pu ...

随机推荐

  1. ylbtech-SubwayNav(地铁线路导航)-数据库设计

    ylbtech-DatabaseDesgin:ylbtech-SubwayNav(地铁线路导航)-数据库设计 DatabaseName:SubwayNav(地铁线路导航) Type:线路导航 1.A, ...

  2. 2、列表item_圆头像_信息提示

    import android.app.Activity; import android.os.Bundle; import android.view.LayoutInflater; import an ...

  3. HDU 4609 3-idiots FFT+容斥

    一点吐槽:我看网上很多分析,都是在分析这个题的时候,讲了半天的FFT,其实我感觉更多的把FFT当工具用就好了 分析:这个题如果数据小,统计两个相加为 x 的个数这一步骤(这个步骤其实就是求卷积啊),完 ...

  4. duilib combo控件,当鼠标滚动时下拉列表自动关闭的bug的修复

    转载请说明出处,谢谢~~ 群里有朋友提到了使用Combo控件时,当下拉列表出现,此时鼠标滚轮滚动,下拉列表就自动消失了.我看了一下源码,这个bug的修复很简单. CComboUI控件被单击时创建CCo ...

  5. android Loger日志类(获取内置sd卡)

    Android手机自带内部存储路径的获取 原文地址:http://my.oschina.net/liucundong/blog/288183 直接贴代码: public static String g ...

  6. gcc编译器基本命令和vi编辑器2

    !1 os fen时 看电影 聊天.支持多核处理器 分任务 已经绝迹cpu Trobe c 分任务操作系统三大组成部分内核,命令解释器(shell外壳),文件系统2修改文件日期或(创建文件)命令:to ...

  7. 内核源码分析之linux内核栈(基于3.16-rc4)

    在3.16-rc4内核源码中,内核给每个进程分配的内核栈大小为8KB.这个内核栈被称为异常栈,在进程的内核空间运行时或者执行异常处理程序时,使用的都是异常栈,看下异常栈的代码(include/linu ...

  8. Java 从单核到多核的多线程(并发)

    JAVA 并发编程       最初计算机是单任务的,然后发展到多任务,接着出现多线程并行,同时计算机也从单cpu进入到多cpu.如下图: 多任务:其实就是利用操作系统时间片轮转使用的原理.操作系统通 ...

  9. ctags支持的语言

    http://ctags.sourceforge.net/languages.html Languages Supported by Exuberant Ctags: Ant Assembler AS ...

  10. wine的中文字体显示

    从1.1.4开始wine的界面就已经支持中文了,但是对于软件中的中文支持并不太好,主要原因.还是字体...Let's go 首先,copy一下字体:把simsun.ttc (即宋体)复制到 ~/.wi ...