设计模式与软考试题之桥接模式
2009年上半年软件设计师考试下午试题最后一题考查桥接模式,原题如下:
【全国计算机技术与软件专业技术资格(水平)考试 2009年上半年 软件设计师 下午试卷】
注:当年试题五、试题六和试题七三选一,试题六为C++版,试题七为Java版。
试题六
阅读以下说明和 C++代码,将应填入 (n) 处的字句写在答题纸的对应栏内。
【说明】
现欲实现一个图像浏览系统,要求该系统能够显示BMP、JPEG和GIF三种格式的文件,并且能够在Windows和Linux两种操作系统上运行。系统首先将BMP、JPEG和GIF三种格式的文件解析为像素矩阵,然后将像素矩阵显示在屏幕上。系统需具有较好的扩展性以支持新的文件格式和操作系统。为满足上述需求并减少所需生成的子类数目,采用桥接(Bridge)设计模式进行设计所得类图如图6-1所示。
图6-1 类图
采用该设计模式的原因在于:系统解析BMP、JPEG与GIF文件的代码仅与文件格式相关,而在屏幕上显示像素矩阵的代码则仅与操作系统相关。
【C++代码】
class Matrix{ //各种格式的文件最终都被转化为像素矩阵
//此处代码省略
};
class ImageImp{
public:
virtual void doPaint(Matrix m) = 0; //显示像素矩阵m
};
class WinImp : public ImageImp{
public:
void doPaint(Matrix m){ /*调用windows系统的绘制函数绘制像素矩阵*/ }
};
class LinuxImp : public ImageImp{
public:
void doPaint(Matrix m){ /*调用Linux系统的绘制函数绘制像素矩阵*/ }
};
class Image {
public:
void setImp(ImageImp *imp) { (1) = imp;}
virtual void parseFile(string fileName) = 0;
protected:
(2) *imp;
};
class BMP : public Image{
public:
void parseFile(string fileName){
//此处解析BMP 文件并获得一个像素矩阵对象m
(3) ;// 显示像素矩阵m
}
};
class GIF : public Image{
//此处代码省略
};
class JPEG : public Image{
//此处代码省略
};
void main(){
//在Windows操作系统上查看demo.bmp图像文件
Image *image1 =(4) ;
ImageImp *imageImp1 =(5) ;
(6) ;
image1->parseFile("demo.bmp");
}
现假设该系统需要支持10种格式的图像文件和5种操作系统,不考虑类Matrix,若采用桥接设计模式则至少需要设计(7) 个类。
试题七
阅读以下说明和 Java代码,将应填入 (n) 处的字句写在答题纸的对应栏内。
【说明】
现欲实现一个图像浏览系统,要求该系统能够显示BMP、JPEG和GIF三种格式的文件,并且能够在Windows和Linux两种操作系统上运行。系统首先将BMP、JPEG和GIF三种格式的文件解析为像素矩阵,然后将像素矩阵显示在屏幕上。系统需具有较好的扩展性以支持新的文件格式和操作系统。为满足上述需求并减少所需生成的子类数目,采用桥接(Bridge)设计模式进行设计所得类图如图7-1所示。
图7-1 类图
采用该设计模式的原因在于:系统解析BMP、JPEG与GIF文件的代码仅与文件格式相关,而在屏幕上显示像素矩阵的代码则仅与操作系统相关。
【Java代码】
class Matrix { //各种格式的文件最终都被转化为像素矩阵
//此处代码省略
}
interface ImageImp {
public void doPaint(Matrix m); //显示像素矩阵m
}
class WinImp implements ImageImp {
public void doPaint(Matrix m) {/*调用Windows系统的绘制函数绘制像素矩阵*/}
}
class LinuxImp implements ImageImp {
public void doPaint(Matrix m) {/*调用Linux系统的绘制函数绘制像素矩阵*/}
}
abstract class Image {
public void setImp(ImageImp imp) {
(1) = imp; }
public abstract void parseFile(String fileName);
protected (2) imp;
}
class BMP extends Image {
public void parseFile(String fileName) {
//此处解析BMP文件并获得一个像素矩阵对象m
(3) ;//显示像素矩阵m
}
}
class GIF extends Image {
//此处代码省略
}
class JPEG extends Image {
//此处代码省略
}
public class Main{
public static void main(String[] args)
{
//在Windows操作系统上查看demo.bmp图像文件
Image image1 = (4) ;
ImageImp imageImp1 = (5);
(6) ;
image1.parseFile("demo.bmp");
}
}
现假设该系统需要支持10种格式的图像文件和5种操作系统,不考虑类Matrix,若采用桥接设计模式则至少需要设计(7) 个类。
------------------------------------------------------------------------------------------------------------------------------------------------------
分析与解答:
本题是桥接模式的一个应用实例,在本实例所述系统中,存在文件格式和操作系统两个独立变化的维度,这两个维度都需要独立进行扩展和维护,因此可以使用桥接模式来进行设计与实现。
在本实例的类图中,抽象图像文件类Image充当Abstraction(抽象类),具体图像文件类BMP、GIF和JPEG充当RefinedAbstraction(扩充抽象类),ImageImp充当Implementor(实现类接口),而两种不同操作系统的实现类WinImp和LinuxImp充当ConcreteImplementor(具体实现类)。
根据桥接模式的实现原理,在抽象类Image中维持了一个对实现类接口ImageImp类型对象的引用,正因为在两个维度的抽象层之间存在一个高层的关联关系,其形状类似一条桥,“桥接模式”故此得名。因此,第(2)空为实现类接口ImageImp。在程序运行时,可以通过构造方法或者Setter方法将一个实现ImageImp接口的子类对象注入到Image对象中,但是在定义的时候仍使用ImageImp作为传入参数的类型,根据里氏代换原则,任何ImageImp的子类对象都可以在运行时覆盖由ImageImp定义的对象,不难得知,第(1)空为给ImageImp类型的成员变量imp赋值,答案为this->imp【C++】或this.imp【Java】,此处使用的是Setter注入。
根据实例说明,系统解析BMP、JPEG与GIF文件的代码仅与文件格式相关,而在屏幕上显示像素矩阵的代码则仅与操作系统相关,在获得一个特定格式的像素矩阵之后,在不同的操作系统中其显示程序有所不同,因此需要调用ImageImp 子类的doPaint()方法来显示像素矩阵,第(3)空略有难度,根据多态和里氏代换原则,ImageImp子类对象在运行时才注入,而在代码中统一使用ImageImp类型的imp来编程实现,这体现了“依赖倒转原则”,即针对抽象(接口)编程,而不针对具体编程。由此可知,第(3)空为调用imp对象的显示像素矩阵方法doPaint()来显示图像【注意方法的参数】,答案为imp -> doPaint(m)【C++】或imp.doPaint(m)【Java】。
第(4)-(6)空考查客户端代码的编写,由于在代码注释中已经明确指出“在Windows操作系统上查看demo.bmp图像文件”,因此图像文件的格式为BMP类型,且显示在Windows操作系统中,我们只需从两个维度中选择对应的具体类,并实例化成对象,然后将对象进行组合即可。image1的类型为BMP,imageImp1的类型为WinImp,第(4)空用于创建一个BMP类型的图像对象,而第(5)空用于创建一个WinImp类型的对象。第(6)空需要仔细考虑,该空用于将对象进行组合,即将对象imageImp1注入到对象image1中,答案为image1 -> setImp(imageImp1)【C++】或image1.setImp(imageImp1)。
最后一空考查桥接模式对整个系统设计的影响,要求计算使用桥接模式之后系统中类的个数。桥接模式的优点之一就是避免类的个数出现爆炸式增长,减少类的个数。如果不使用桥接模式而使用多层继承结构,具体类的个数为两个维度类型数目的乘积,而使用桥接模式之后,具体类的个数仅为两个维度类型数目之和。因此当系统需要支持10种格式的图像文件和5种操作系统时(不考虑类Matrix),如果采用桥接模式,只需要 10 + 5 = 15个具体类,再加上两个抽象层类,至少需要设计17个类;如果不采用桥接模式,而使用多层继承,则所需的具体类数目为 10 * 5 = 50个,再加上各种抽象层和中间层的类,类的个数要远远超过17个,因此,桥接模式的引入将简化系统设计,减少系统中类的个数,并使得系统扩展起来更加灵活。
推荐:深入学习桥接模式
参考答案:
【试题六】
(1) this -> imp
(2) ImageImp
(3) imp -> doPaint(m)
(4) new BMP 或 new BMP()
(5) new WinImp 或 new WinImp()
(6) image1 -> setImp(imageImp1)
(7) 17
【试题七】
(1) this.imp
(2) ImageImp
(3) imp.doPaint(m)
(4) new BMP()
(5) new WinImp()
(6) image1.setImp(imageImp1)
(7) 17
【作者:刘伟 http://blog.csdn.net/lovelion】
设计模式与软考试题之桥接模式相关推荐
- 设计模式与软考试题之状态模式(二)
2011年下半年软件设计师考试下午试题最后一题考查状态模式,在本试题中,命题人设计了一个具有多个状态的纸巾售卖机,真题如下: [全国计算机技术与软件专业技术资格(水平)考试 2011 年下半年 软件 ...
- 设计模式与软考试题之模板方法模式
2008年下半年软件设计师考试下午试题最后一题考查模板方法模式,原题如下: [全国计算机技术与软件专业技术资格(水平)考试 2008年下半年 软件设计师 下午试卷] 注:当年试题五.试题 ...
- Java设计模式之结构型:桥接模式
一.什么是桥接模式: 桥接,顾名思义,就是用来连接两个部分,使得两个部分可以互相通讯,桥接模式的作用就是为被分离的抽象部分和实现部分搭桥.在现实生活中一个物品在搭配不同的配件时会产生不同的动作和结果, ...
- 设计模式(16):结构型-桥接模式(Bridge)
设计模式(Design pattern)是一套被反复使用.多数人知晓的.经过分类编目的.代码设计经验的总结.使用设计模式是为了可重用代码.让代码更容易被他人理解.保证代码可靠性. 毫无疑问,设计模式于 ...
- 设计模式(七):桥接模式
优点: ① 分离抽象接口及其实现部分.提高了比继承更好的解决方案. ② 桥接模式提高了系统的可扩充性,在两个变化维度中任意扩展一个维度,都不需要修改原有系统. 缺点: ① 桥接模式的引入会增加系统的理 ...
- 设计模式之结构型(4)-桥接模式(Bridge)
(一)定义:将抽象部分与它的实现部分分离,使它们都可以独立地变化.(将一个对象多维度的变化分离) ① 桥接模式主要用意是为了实现抽象部分与实现部分脱耦,使它们各自可以独立变化. ② 在开发过程中通常会 ...
- 23种经典设计模式的java实现_3_桥接模式
桥接模式的适用: 你不希望在抽象和它的实现部分之间有一个固定的绑定关系.例如:程序的实现部分在运行时需要被选择或者切换. 类的抽象以及它的实现都应该可以通过生成子类的方法加以扩充.这时Bridge模式 ...
- 设计模式解密(12)- 桥接模式
1.简介 定义:将抽象部分与实现部分分离,使它们都可以独立的变化. 主要解决:在多维可能会变化的情况下,用继承会造成类爆炸问题,扩展起来不灵活. 何时使用:实现系统可能有多个角度分类,每一种角度都可能 ...
- 设计模式(十五)——桥接模式
1.描述 将桥接部分与他的实现部分分离,是他们都可以独立的变化. 2.模式的使用 ·抽象(Abstraction):是一个抽象类,该抽象类含有Implementor的声明,即维护一个Implement ...
最新文章
- P4779 【模板】单源最短路径(标准版)(dijkstra模板)
- 14Web APIs简介
- 一个JavaBean和DTO转换的优秀案例
- 2053. 数组中第 K 个独一无二的字符串
- .NET设计模式(1): 简单工厂模式
- CentOS 7.x下部署和配置zabbix 3.2.x监控工具
- 初识STM32与其选型
- gitee创建仓库,并将代码上传到gitee上
- HTML文本格式化标签(用来调整文本的格式和排版)
- uni-app web-view跳转自定义html
- 拦截CSDN顶端广告
- java计算器课程_Java课程设计——计算器团队博客
- 2022江苏民丰农村商业银行社会招聘测试题及答案
- JAVA计算机毕业设计桌游店会员管理系统Mybatis+系统+数据库+调试部署
- TikZ绘制多样的花括号
- a job is a job
- 小鸟伏特加怎么用计算机,生活常识:小鸟伏特加是什么梗
- 网络视频教程(共57个)全实战过程
- 使用OD加载微软符号库
- 镜头桶形失真校正算法