内容简介:先不说定义直接来看一个问题,有一个手机抽象类里面有两个抽象方法,获得手机型号和内存大小。现在我们想实例化小米10这个型号的手机两个方法可能看起来不明显,是1x2,如果现在多出一个方法是getRom,Rom的种类有3种,128,256,512。那么需要的类就变成了1x2x3,属性越多需要的类就越多,这样维护起来就很麻烦。这时候我们就需要用组合解决这个子类爆炸的问题
桥接模式
先不说定义直接来看一个问题,有一个手机抽象类
public abstract class Phone{
public abstract void getName();
public abstract void getRam();
}
里面有两个抽象方法,获得手机型号和内存大小。现在我们想实例化小米10这个型号的手机
public class Mi106g extends Phone {
@Override
public void getName() {
System.out.println("小米10");
}
@Override
public void getRam() {
System.out.println("6");
}
}
public class Mi1068g extends Phone {
@Override
public void getName() {
System.out.println("小米10");
}
@Override
public void getRam() {
System.out.println("8");
}
}
两个方法可能看起来不明显,是1x2,如果现在多出一个方法是getRom,Rom的种类有3种,128,256,512。那么需要的类就变成了1x2x3,属性越多需要的类就越多,这样维护起来就很麻烦。这时候我们就需要用组合解决这个子类爆炸的问题
public abstract class Phone {
Ram ram;
public void setRam(Ram ram){
this.ram = ram;
}
public abstract void model();
}
public abstract class Ram {
public abstract void getRam();
}
现在Ram作为一个单独的类,和Phone组合
public class Mi10 extends Phone {
@Override
public void model() {
System.out.println("Mi10");
}
}
public class Ram6 extends Ram {
@Override
public void getRam() {
System.out.println("6g");
}
}
public class Ram8 extends Ram {
@Override
public void getRam() {
System.out.println("8g");
}
}
那我们要获得一个6g的Mi10怎么来弄呢
Phone Mi106g = new Mi10(); Mi106g.setRam(new Ram6());
或者是设置在构造函数里,重点在于组合。
现在来看一下桥接模式的定义
将抽象部分与它的实现部分分离,使它们都可以独立地变化。
我感觉这个确实有点抽象不太好理解,这里不是说编程语言里的抽象和实现,结合上面的例子,手机的型号可以理解为抽象,Ram理解为实现,因为手机型号是一个笼统的概念,而Ram就是内存本身,通过把他俩分离开来,型号可以单独的变化,内存大小也可以单独的变化,然后再组合到一起。
总结
个人觉的桥接模式就是用组合避免继承子类爆炸问题
以上所述就是小编给大家介绍的《桥接模式》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- Java设计模式(十二)桥接模式
- 结构型模式:桥接模式 原 荐
- Golang桥接模式将多个chan桥接成一个chan
- [Unity 设计模式]桥接模式(BridgePattern)
- 结构型设计模式之桥接模式
- 桥接模式的解析-iOS
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
数据结构与算法经典问题解析
纳拉辛哈·卡鲁曼希 / 骆嘉伟 / 机械工业出版社 / 2016-6-1 / CNY 79.00
本书是一本数据结构方面的优秀教材,以Java为描述语言,介绍了计算机编程中使用的数据结构和算法。本书强调问题及其分析,而非理论阐述,共分为21章,讲述了基本概念、递归和回溯、链表、栈、队列、树、优先队列和堆、并查集DAT、图算法、排序、查找、选择算法(中位数)、符号表、散列、字符串算法、算法设计技术、贪婪算法、分治算法、动态规划算法、复杂度类型等内容。每章首先阐述必要的理论基础,然后给出问题集。全......一起来看看 《数据结构与算法经典问题解析》 这本书的介绍吧!