桥接模式和访问者模式

桥接模式:

               将抽象部分(属性)与它的实现部分分离,使它们都可以独立地变化;

 访问者模式:

                  表示一个作用于某对象结构中的各元素的操作。

                  它使你可以在不改变各元素的类的前提下定义作用于这些元素的新操作。

相同:

          可动态添加新功能

不同:

         ①侧重点不同:

                                  桥接模式主要用于将对象的抽象部分和实现部分隔离,使得各自承担责任,可独立变化。

                                  访问者模式主要用于为某对象结构中包含的多类对象灵活添加新功能。

        ②添加的功能关系:

                                   桥接模式添加的方法彼此不相同,但相关

                                   访问者模式添加的新功能彼此不相同且不相关。如为用户结构下的不同用户对象(超级用户、普通用户)添加打印、扫描方法

       ③访问者模式通过对象结构遍历所有分类对象。

           桥接模式没有对象结构,通过在抽象超类的属性中定义接口对象(如IOperation  operation;

           通过setter方法将不同的具体IOperation对象添加至超类的某一子类对象,从而实现新方法的添加。

桥接模式示例代码如下:

          用户超类:

public class CUser
{
      IOperation operation;
      public void setOperation(IOperation oper)
      {
            this.operation = oper;
       }
     public abstract void doOperation();
}


 子类的实现:

public class CSuperUser  extends CUser
{
    public void doOperation()
     {
          this.operation.work();
      }

}

   operation接口:

public interface IOperation
{ 
    public void work(); 
}



待添加的operation(扫描操作、打印操作): 

扫描操作:

public class CScanner implements IOperation
{
   public void  work()
{
    System.out.println("实现扫描操作;");
}
}

 打印操作:

public class CPrinter implements IOperation
{
   public void  work()
{
    System.out.println("实现打印操作;");
}
}

 

 测试代码:

public class CTest
{
  IOperation p1 = new CPrinter();
  CUser su = new CSuperUser();
  su.setOperation(p1);  
  su.doOperation();
  IOperation p2 = new CScanner();
  su.setOperation(p2);
  su.doOperation();
}


 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
25.1 场景问题 25.1.1 扩展客户管理的功能 考虑这样一个应用:扩展客户管理的功能。 既然是扩展功能,那么肯定是已经存在一定的功能了,先看看已有的功能:公司的客户分成两大类,一类是企业客户,一类是个人客户,现有的功能非常简单,就是能让客户提出服务申请。目前的程序结构如图25.1所示: 图25.1 已有的客户管理程序结构示意图 现有的实现很简单,先看看Customer的实现,示例代码如下: /** * 各种客户的父类 */ public abstract class Customer { /** * 客户编号 */ private String customerId; /** * 客户名称 */ private String name; /** * 客户提出服务请求的方法,示意一下 */ public abstract void serviceRequest(); } 接下来看看企业客户的实现示例代码如下: /** * 企业客户 */ public class EnterpriseCustomer extends Customer{ /** * 联系人 */ private String linkman; /** * 联系电话 */ private String linkTelephone; /** * 企业注册地址 */ private String registerAddress; /** * 企业客户提出服务请求的方法,示意一下 */ public void serviceRequest(){ //企业客户提出的具体服务请求 System.out.println(this.getName()+"企业提出服务请求"); } } 再看看个人客户的实现示例代码如下: /** * 个人客户 */ public class PersonalCustomer extends Customer{ /** * 联系电话 */ private String telephone; /** * 年龄 */ private int age; /** * 企业注册地址 */ private String registerAddress; /** * 个人客户提出服务请求的方法,示意一下 */ public void serviceRequest(){ //个人客户提出的具体服务请求 System.out.println("客户"+this.getName()+"提出服务请求"); } } 从上面的实现可以看出来,以前对客户的管理功能是很少的,现在随着业务的发展,需要加强对客户管理的功能,假设现在需要增加如下的功能: 客户对公司产品的偏好分析,针对企业客户和个人客户有不同的分析策略,主要是根据以往购买的历史、潜在购买意向等进行分析,对于企业客户还要添加上客户所在行业的发展趋势、客户的发展预期等的分析。 客户价值分析,针对企业客户和个人客户,有不同的分析方式和策略。主要是根据购买的金额大小、购买的产品和服务的多少、购买的频率等进行分析。 其实除了这些功能,还有很多潜在的功能,只是现在还没有要求实现,比如:针对不同的客户进行需求调查;针对不同的客户进行满意度分析;客户消费预期分析等等。虽然现在没有要求实现,但不排除今后有可能会要求实现。 25.1.2 不用模式的解决方案 要实现上面要求的功能,也不是很困难,一个很基本的想法就是:既然不同类型的客户操作是不同的,那么在不同类型的客户里面分别实现这些功能,不就可以了。 由于这些功能的实现依附于很多其它功能的实现,或者是需要很多其它的业务数据,在示例里面不太好完整的体现其功能实现,都是示意一下,因此提前说明一下。
单例模式:单例模式是一种设计模式,它提供一种方法,通过保证只有一个实例来控制对象的创建。 工厂模式:工厂模式是一种设计模式,其中定义一个创建对象的接口,但让子类来决定实例化哪一个类。这使得类的实例化推迟到子类。 抽象工厂模式:抽象工厂模式是一种设计模式,其中提供一个接口,用于创建相关或依赖对象的家族,而不需要明确指定具体类。 建造者模式:建造者模式是一种设计模式,其中可以创建复杂对象的算法被抽象化,从而隐藏了那些创建对象的实现细节。 原型模式:原型模式是一种设计模式,其中允许复制现有对象的实例,而无需创建新的实例。 适配器模式:适配器模式是一种设计模式,它允许一个类使用另一个类的接口。 桥接模式桥接模式是一种设计模式,它将抽象部分和它的实现部分分离,从而使它们可以独立地变化。 组合模式:组合模式是一种设计模式,其中允许您将对象组合成树形结构以表示“部分-整体”层次结构。 装饰模式:装饰模式是一种设计模式,其中可以动态地向对象添加额外的职责。 外观模式:外观模式是一种设计模式,其中提供了一个统一的接口,用于访问子系统中的一组接口,从而将子系统与客户端解耦。 享元模式:享元模式是一种设计模式,其中可以共享相同内部状态的对象,从而有效地支持大量细粒度的对象。 代理模式:代理模式是一种设计模式,其中一个类代表另一个类,以控制对该类的访问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值