Android Ap 开发 设计模式第九篇:桥接模式

简介:

Bridge Pattern

模式解读

  bridge 是“桥梁”的意思。就像现实社会里的桥梁担负着连接两岸的重大责任一样,Bridge Pattern也是负责连接2个不同位置的参与者。

  桥接模式沟通着“功能的类层次”和“实现的类层次”。将“功能的类层次”和“实现的类层次”分成2个独立的类层次可能会弄得支离破碎,所以必须在2个类层次之间建一座沟通的桥梁。

 

程序示例

  按照上面的分法,本例可以分为4个类按照“功能的类层次”和“实现的类层次”分开,分别为:

功能的类层次

  Display   该类为打印内容的类

  CountDisplay   该类不仅可以打印内容还可以参数指定打印次数

实现的类层次

  DisplayImpl  该类为抽象类,抽象出打印内容所需要的功能

  StringDisplayImpl  该类实现了DisplayImpl 所抽象出来的功能

 

  按照如上划分,制作出了UML图,如下:

 

  功能的类层次:Display 类,代码:

 

public   class  Display {

    
private  DisplayImpl impl;

    
public  Display(DisplayImpl impl) {
        
this .impl  =  impl;
    }

    
public  String open() {
        
return  impl.rawOpen();
    }

    
public  String print() {
        
return  impl.rawPrint();
    }

    
public  String close() {
        
return  impl.rawClose();
    }

    
public  final String display() {
        open();

        String text 
=  print();

        close();
        
return  text;
    }
}

  该类通过参数将DisplayImpl传进来,直接让Display 有DisplayImpl的功能。该功能也是Builder Pattern 的模式。位于“功能的类层次”最上层的类,利用接口参与者的方法只记载基本功能的类。这个对象实例是保持住接口参与者。该类为扮演这个参与者的类。

 

  功能的类层次:CountDisplay类 ,代码:

 

public   class  CountDisplay extends Display {

    
public  CountDisplay(DisplayImpl impl) {
        super(impl);
        
//  TODO Auto-generated constructor stub
    }

    
public  String multiDisplay( int  times) {
        StringBuffer sb 
=   new  StringBuffer();
        sb.append(open()
+ " \n " );
        
for  ( int  i  =   0 ; i  <  times; i ++ ) {
            sb.append(print()
+ " \n " );
        }
        
return  sb.append(close()).toString();
    }
}

 

  该类系Display 的子类,并且再添加一个可按照次数循环打印的方法。对抽象参与者新增功能的参与者(改良后的抽象化),该类扮演在这个DEMO中扮演着这个角色。

 

  实现的类层次:DisplayImpl 类,代码:

 

public   abstract   class  DisplayImpl {
    
public   abstract  String rawOpen();
    
    
public   abstract  String rawPrint();
    
    
public   abstract  String rawClose();
}

  

  该类位于实现的类层次的最上层,分别抽象了rawOpen、rawPrint、rawClose三个方法,这三个方法分别对应到Display 类的open、print、close方法,执行前处理、打印和后处理。规定要实现的抽象参与者的接口 。

 

  实现的类层次:StringDisplayImpl 类,代码:

 

public   class  StringDisplayImpl extends DisplayImpl{

    
    
private  String  string ;    
    
    
public  StringDisplayImpl(String str){
        
this . string = str;
    }
    
    @Override
    
public  String rawClose() {
        
//  TODO Auto-generated method stub
         return  printLine();
    }

    @Override
    
public  String rawOpen() {
        
//  TODO Auto-generated method stub
         return     printLine();
    }

    @Override
    
public  String rawPrint() {
        
//  TODO Auto-generated method stub
         return   " | " + string + " | " ;
    }
    
    
private  String printLine(){
        StringBuffer sb
= new  StringBuffer();
        sb.append(
" + " );
        
for ( int  i = 0 ;i < string .length();i ++ ){
            sb.append(
" - " );
        }
        
return  sb.append( " + " ).toString();
    }

}

  

  该类实现了DisplayImpl的三个抽象方法,本例中唯一一处实现功能的也是由本类完成。具体实现接口 参与者的接口 。

 

  界面入口:BridgePatternActivity 类,代码:

public   class  BridgePatternActivity extends Activity {
    
/* * Called when the activity is first created.  */
    @Override
    
public   void  onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        
        
        ((Button)findViewById(R.id.Button01)).setOnClickListener(
new  OnClickListener() {
            
            @Override
            
public   void  onClick(View v) {
                
//  TODO Auto-generated method stub
                
                
                Display display
= new  Display( new  StringDisplayImpl( " terry_龙 " ));
                
                CountDisplay mCountDisplay
= new  CountDisplay( new  StringDisplayImpl( " terry " ));
                
                ((EditText)findViewById(R.id.EditText01)).setText(display.print());
                
                
                ((EditText)findViewById(R.id.EditText02)).setText(mCountDisplay.multiDisplay(
5 ));
                
            }
        });
        
    }
}


运行结果:

 

  代码下载:

桥接模式





 本文转自 terry_龙 51CTO博客,原文链接:http://blog.51cto.com/terryblog/624082,如需转载请自行联系原作者


相关文章
|
1天前
|
Android开发 开发者 Kotlin
探索安卓开发中的新特性
【9月更文挑战第14天】本文将引导你深入理解安卓开发领域的一些最新特性,并为你提供实用的代码示例。无论你是初学者还是经验丰富的开发者,这篇文章都会给你带来新的启示和灵感。让我们一起探索吧!
|
5天前
|
IDE 开发工具 Android开发
安卓与iOS开发对比:平台选择对项目成功的影响
【9月更文挑战第10天】在移动应用开发的世界中,选择正确的平台是至关重要的。本文将深入探讨安卓和iOS这两大主要移动操作系统的开发环境,通过比较它们的市场份额、开发工具、编程语言和用户群体等方面,为开发者提供一个清晰的指南。我们将分析这两个平台的优势和劣势,并讨论如何根据项目需求和目标受众来做出最佳选择。无论你是初学者还是有经验的开发者,这篇文章都将帮助你更好地理解每个平台的特性,并指导你做出明智的决策。
|
1天前
|
XML 编解码 Android开发
安卓开发中的自定义视图控件
【9月更文挑战第14天】在安卓开发中,自定义视图控件是一种高级技巧,它可以让开发者根据项目需求创建出独特的用户界面元素。本文将通过一个简单示例,引导你了解如何在安卓项目中实现自定义视图控件,包括创建自定义控件类、处理绘制逻辑以及响应用户交互。无论你是初学者还是有经验的开发者,这篇文章都会为你提供有价值的见解和技巧。
|
3天前
|
API Android开发 iOS开发
安卓与iOS开发中的线程管理对比
【9月更文挑战第12天】在移动应用的世界中,安卓和iOS平台各自拥有庞大的用户群体。开发者们在这两个平台上构建应用时,线程管理是他们必须面对的关键挑战之一。本文将深入探讨两大平台在线程管理方面的异同,通过直观的代码示例,揭示它们各自的设计理念和实现方式,帮助读者更好地理解如何在安卓与iOS开发中高效地处理多线程任务。
|
4天前
|
搜索推荐 Android开发 UED
安卓开发中的自定义视图:打造个性化用户界面
【9月更文挑战第11天】在安卓应用开发领域,自定义视图是实现独特用户体验的基石。本文将引导你通过一个简单的自定义视图示例,探索如何从零开始创建并应用自定义组件,以增强你的应用界面。我们将一起学习如何扩展View类,重写onDraw方法,处理触摸事件,并最终在我们的安卓项目中使用这个自定义视图。无论你是初学者还是有一定经验的开发者,这篇文章都将为你提供清晰的步骤和实用的技巧,帮助你提升用户界面设计的能力。
|
5天前
|
开发工具 Android开发 Swift
探索安卓与iOS开发的差异:从新手到专家的旅程
在数字时代的浪潮中,移动应用开发已成为连接世界的桥梁。本文将深入探讨安卓与iOS这两大主流平台的开发差异,带领读者从零基础出发,逐步了解各自的特点、开发环境、编程语言及市场策略。无论你是梦想成为移动应用开发者的初学者,还是希望扩展技能边界的资深开发者,这篇文章都将为你提供宝贵的见解和实用的建议。
|
5天前
|
Linux Android开发 iOS开发
探索Android与iOS开发:平台之战还是互补共生?
在移动应用开发的浩瀚宇宙中,Android和iOS这两大星系始终吸引着无数开发者的目光。它们各自拥有独特的引力场,引领着技术潮流的方向。本文将穿梭于这两个平台的星际空间,揭示它们背后的力量对比,以及如何在这两者之间找到平衡点,共同推动移动应用开发的进步。
14 1
|
1天前
|
设计模式 安全 数据库连接
后端开发中的设计模式应用
在软件开发的浩瀚海洋中,设计模式如同灯塔,为后端开发者指引方向。它们不仅仅是代码的模板,更是解决复杂问题的智慧结晶。本文将深入探讨几种常见的设计模式,包括单例模式、工厂模式和观察者模式,并揭示它们在实际应用中如何提升代码的可维护性、扩展性和重用性。通过实例分析,我们将一窥这些模式如何在后端开发中大放异彩,助力构建高效、灵活的软件系统。
|
2天前
|
设计模式 算法 安全
设计模式——模板模式
模板方法模式、钩子方法、Spring源码AbstractApplicationContext类用到的模板方法
设计模式——模板模式
|
28天前
|
设计模式
设计模式-单一职责模式
设计模式-单一职责模式