Design Pattern 17-Mediator

本文介绍了中介者模式,该模式用中介对象封装对象交互,降低复杂度,使原本的多对多关系变为1对多关系。通过小王、小李、小张交换物品的例子进行说明,还给出了接口和类的代码实现,展示了如何使用中介者进行物品交换。
部署运行你感兴趣的模型镜像

using System;
using System.Collections ;

namespace Pattern
{
 /// <summary>
 /// Summary description for Class1.
 /// </summary>
 /*这个模式的定义就很简单用一个中介对象来封装一系列的对象交互。中介者

 使各对象不需要显式地相互引用,从而使其耦合松散,而且可以独立地改变

 它们之间的交互。好处是什么呢?很显然就是为了降低复杂度.使的原本使多

 对多关系.现在变成了1对多关系.因为所有对象都只和Mediator中介者单线联

 系.而中介者隐士的包含了对象之间的关系.下面还是举个简单的事例.如:小王

 要把稿件交给小李.小李要把书籍交给小张.小张要把笔交给小王.并且小张要

 把随身听交给小李.这样如果对象和对象之间交互会显得很复杂.如果他们只

 是把物品交给一个中介人.在由中介人负责派分物品.这样每个人都只和中介人

 建立联系.而中介人维护对象之间的关系.*/

 //还是从接口开始
 public interface IPerson
 {
  string Name{get;}
  ArrayList Article {get;set;}//每个人可能有多个物品
 }

 public class Wang : IPerson
 {
  private string name="Wang";
  private ArrayList article;

  public string Name
  {
   get{return name;}
  }

  public ArrayList Article
  {
   get{return article;}
   set{article=value;}
  }
  //.......做其他的事情
 }

 public class Zhang : IPerson
 {
  private string name="Zhang";
  private ArrayList article;

  public string Name
  {
   get{return name;}
  }

  public ArrayList Article
  {
   get{return article;}
   set{article=value;}
  }
  //.......做其他的事情
 }

 public class Lee:IPerson
 {
  private string name="Lee";
  private ArrayList article;

  public string Name
  {
   get{return name;}
  }

  public ArrayList Article
  {
   get{return article;}
   set{article=value;}
  }
  //.......做其他的事情
 }


 //中介人
 public interface IMediator
 {
  //交换物品
  void SweapArticle(IPerson p1,IPerson p2,object at);
 }

 public class ConcreteMediator : IMediator
 {
  
  public  void SweapArticle(IPerson p1,IPerson p2,object at)
  {
   p1.Article.Add(at);
   p2.Article.Remove(at);
  }
 }

 
}

   //中介者模式
   
//   IMediator m = new  ConcreteMediator();
//   IPerson wang=new Wang();
//   IPerson zhang=new Zhang();
//   IPerson lee=new Lee();
//
//   wang.Article.Add("稿件");
//   zhang.Article.Add("书籍");
//   lee.Article.Add("笔");
//   lee.Article.Add("随身听");
//
//   //交换开始
//   m.SweapArticle(wang,zhang,"稿件");
//   m.SweapArticle(zhang,lee,"书籍");                                                        
//   m.SweapArticle(lee,zhang,"笔");
//   m.SweapArticle(lee,wang,"随身听"); 

您可能感兴趣的与本文相关的镜像

ACE-Step

ACE-Step

音乐合成
ACE-Step

ACE-Step是由中国团队阶跃星辰(StepFun)与ACE Studio联手打造的开源音乐生成模型。 它拥有3.5B参数量,支持快速高质量生成、强可控性和易于拓展的特点。 最厉害的是,它可以生成多种语言的歌曲,包括但不限于中文、英文、日文等19种语言

【EI复现】基于主从博弈的新型城镇配电系统产消者竞价策略【IEEE33节点】(Matlab代码实现)内容概要:本文介绍了基于主从博弈理论的新型城镇配电系统中产消者竞价策略的研究,结合IEEE33节点系统,利用Matlab进行仿真代码实现。该研究聚焦于电力市场环境下产消者(既生产又消费电能的主体)之间的博弈行为建模,通过构建主从博弈模型优化竞价策略,提升配电系统运行效率与经济性。文中详细阐述了模型构建思路、优化算法设计及Matlab代码实现过程,旨在复现高水平期刊(EI收录)研究成果,适用于电力系统优化、能源互联网及需求响应等领域。; 适合人群:具备电力系统基础知识和一定Matlab编程能力的研究生、科研人员及从事能源系统优化工作的工程技术人员;尤其适合致力于电力市场博弈、分布式能源调度等方向的研究者。; 使用场景及目标:① 掌握主从博弈在电力系统产消者竞价中的建模方法;② 学习Matlab在电力系统优化仿真中的实际应用技巧;③ 复现EI级别论文成果,支撑学术研究或项目开发;④ 深入理解配电系统中分布式能源参与市场交易的决策机制。; 阅读建议:建议读者结合IEEE33节点标准系统数据,逐步调试Matlab代码,理解博弈模型的变量设置、目标函数构建与求解流程;同时可扩展研究不同市场机制或引入不确定性因素以增强模型实用性。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值