1、设计模式实验四DOC实验4 结构型设计模式实验实验学时: 2 每组人数: 1 实验类型: 3 (1:基础性 2:综合性 3:设计性 4:研究性)实验要求: 1 (1:必修 2:选修 3:其它)实验类别: 3 (1:基础 2:专业基础 3:专业 4:其它)一、实验目的熟练使用PowerDesigner和任意一种面向对象编程语言实现几种常见的结构型设计模式,包括适配器模式、组合模式和外观模式,理解每一种设计模式的模式动机,掌握模式结构,学习如何使用代码实现这些模式。二、实验内容1. 现有一个接口DataOperation定义了排序方法sort(int) 和查找方法search(int, int),
2、已知类QuickSort的quickSort(int)方法实现了快速排序算法,类BinarySearch 的binarySearch(int, int)方法实现了二分查找算法。试使用适配器模式设计一个系统,在不修改源代码的情况下将类QuickSort和类BinarySearch的方法适配到DataOperation接口中。绘制类图并编程实现。(要求实现快速排序和二分查找,使用对象适配器实现)2. Windows Media Player和RealPlayer是两种常用的媒体播放器,它们的API结构和调用方法存在区别。现在你的应用程序需要支持这两种播放器API,而且在将来可能还需要支持新的媒体播
3、放器,请问如何设计该应用程序?绘制类图并编程模拟实现。3. 使用组合模式设计一个杀毒软件(AntiVirus)的框架,该软件既可以对某个文件夹(Folder)杀毒,也可以对某个指定的文件(File)进行杀毒,文件种类包括文本文件TextFile、图片文件ImageFile、视频文件VideoFile。绘制类图并编程模拟实现。4. 某教育机构组织结构如下图所示:在该教育机构的OA系统中可以给各级办公室下发公文,试采用组合模式设计该机构的组织结构,绘制相应的类图并编程模拟实现,在客户端代码中模拟下发公文。5. 某软件公司为新开发的智能手机控制与管理软件提供了一键备份功能,通过该功能可以将原本存储在
4、手机中的通信录、短信、照片、歌曲等资料一次性全部拷贝到移动存储介质(例如MMC卡或SD卡)中。在实现过程中需要与多个已有的类进行交互,例如通讯录管理类、短信管理类等,为了降低系统的耦合度,试使用外观模式来设计并编程模拟实现该一键备份功能。 6. 某信息系统需要提供一个数据处理和报表显示模块,该模块可以读取不同类型的文件中的数据并将数据转换成XML格式,然后对数据进行统计分析,最后以报表方式来显示数据。由于该过程需要涉及到多个类,试使用外观模式设计该数据处理和报表显示模块。考虑到有些文件本身已经是XML格式,无须进行格式转换,为了让系统具有更好的扩展性,在系统设计中可以引入抽象外观类。三、实验要
5、求1. 结合实例,正确无误地绘制适配器模式、组合模式和外观模式的模式结构图;2. 使用任意一种面向对象编程语言实现适配器模式、组合模式和外观模式实例,代码运行正确无误。四、实验步骤1. 结合实例,使用PowerDesigner绘制适配器模式实例结构图并用面向对象编程语言实现该模式实例;2. 结合实例,使用PowerDesigner绘制适配器模式实例结构图并用面向对象编程语言实现该模式实例;3. 结合实例,使用PowerDesigner绘制组合模式实例结构图并用面向对象编程语言实现该模式实例;4. 结合实例,使用PowerDesigner绘制组合模式实例结构图并用面向对象编程语言实现该模式实例;
6、5. 结合实例,使用PowerDesigner绘制外观模式实例结构图并用面向对象编程语言实现该模式实例;6. 结合实例,使用PowerDesigner绘制外观模式实例结构图并用面向对象编程语言实现该模式实例。五、实验结果1. 类图: 实现代码:DataOperation.javapublic interface DataOperation public void sort(int n); public int search(int m, int n);Adapter.javapublic class Adapter implements DataOperation private Binary
7、Search bs; private QuickSort qs; public Adapter() qs = new QuickSort(); bs = new BinarySearch(); public void sort(int n) qs.quickSort(n); public int search(int m, int n) return bs.binarySearch(m, n); QuickSort.javapublic class QuickSort public void quickSort(int n) int size = n.length; quickSortMeth
8、od(n, 0, size - 1); public void quickSortMethod(int n, int left, int right) int q; if (left right) q = partition(n, left, right); quickSortMethod(n, left, q - 1); quickSortMethod(n, q + 1, right); public int partition(int n, int left, int right) int shaft = nleft; int temp = 0; while (left shaft) ri
9、ght-; while (nleft shaft) left+; if (nleft = nright) right-; else temp = nleft; nleft = nright; nright = temp; nleft = shaft; return left; BinarySearch.javapublic class BinarySearch public int binarySearch(int m, int n) QuickSort qs = new QuickSort(); int left = 0; qs(m); int right = m.length; while
10、(left n) right = middle - 1; else left = middle + 1; return -1; XMLUtil.javaimport javax.xml.parsers.*;import org.w3c.dom.*;import org.xml.sax.SAXException;import java.io.*;public class XMLUtil /该方法用于从XML配置文件中提取具体类类名,并返回一个实例对象 public static Object getBean() try /创建DOM文档对象 DocumentBuilderFactory dFac
11、tory = DocumentBuilderFactory.newInstance(); DocumentBuilder builder = dFactory.newDocumentBuilder(); Document doc; doc = builder.parse(new File(src/config.xml); /获取包含类名的文本节点 NodeList nl = doc.getElementsByTagName(className); Node classNode=nl.item(0).getFirstChild(); String cName=classNode.getNodeV
12、alue(); /通过类名生成实例对象并将其返回 Class c=Class.forName(cName); Object obj=c.newInstance(); return obj; catch(Exception e) e.printStackTrace(); return null; Client.javapublic class Client public static void main(String args) int m = 5, 4, 8, 7, 9, 2, 3, 1, 0, 6; DataOperation dataoperation; dataoperation = (
13、DataOperation)XMLUtil.getBean(); dataoperation.sort(m); for(int i=0; i m.length; i+) System.out.print(mi + ); System.out.println(n + dataoperation.search(m, 6); 2. 类图: 实现代码:Player.javapublic interface Player public abstract void play(String fileName);WMPAdapter.javapublic class WMPAdapter implements
14、 Player private WindowsMediaPlayer wmp; public WMPAdapter() wmp = new WindowsMediaPlayer(); public void play(String fileName) wmp.play(fileName); RPAdapter.javapublic class RPAdapter implements Player private RealPlayer rp; public RPAdapter() rp = new RealPlayer(); public void play(String fileName)
15、rp.play(fileName); WindowsMediaPlayer.javapublic class WindowsMediaPlayer public void play(String fileName) System.out.println(fileName + 用 WindowsMediaPlayer 播放); RealPlayer.javapublic class RealPlayer public void play(String fileName) System.out.println(fileName + 用 RealPlayer 播放); ;XMLUtil.javaim
16、port javax.xml.parsers.*;import org.w3c.dom.*;import org.xml.sax.SAXException;import java.io.*;public class XMLUtil /该方法用于从XML配置文件中提取具体类类名,并返回一个实例对象 public static Object getBean() try /创建DOM文档对象 DocumentBuilderFactory dFactory = DocumentBuilderFactory.newInstance(); DocumentBuilder builder = dFactor
17、y.newDocumentBuilder(); Document doc; doc = builder.parse(new File(src/config.xml); /获取包含类名的文本节点 NodeList nl = doc.getElementsByTagName(className); Node classNode=nl.item(0).getFirstChild(); String cName=classNode.getNodeValue(); /通过类名生成实例对象并将其返回 Class c=Class.forName(cName); Object obj=c.newInstanc
18、e(); return obj; catch(Exception e) e.printStackTrace(); return null; Client.javapublic class Client public static void main(String args) Player p; p = (Player)XMLUtil.getBean(); p.play(Rush Hour); 3. 类图:实现代码:AbstractFile.javapublic abstract class AbstractFile public abstract void killVirus(); Folde
19、r.javaimport java.util.ArrayList;public class Folder extends AbstractFile private String fileName; private ArrayList fileList = new ArrayList(); public void killVirus() System.out.println(对文件夹 + fileName + 杀毒); /调用文件夹内成员的杀毒方法 for(Object obj:fileList) (AbstractFile)obj).killVirus(); public void add(A
20、bstractFile abFile) fileList.add(abFile); public void remove(AbstractFile abFile) fileList.remove(abFile); public Folder(String fileName) this.fileName = fileName; public AbstractFile getChild(int n) return fileList.get(n); ImageFile.javapublic class ImageFile extends AbstractFile private String fil
21、eName; public void killVirus() System.out.println(对图像文件 + fileName + 杀毒); public ImageFile(String fileName) this.fileName = fileName; TextFile.javapublic class TextFile extends AbstractFile private String fileName; public void killVirus() System.out.println(对文本文件 + fileName + 杀毒); public TextFile(St
22、ring fileName) this.fileName = fileName; public class VideoFile extends AbstractFile private String fileName; public void killVirus() System.out.println(对视频文件 + fileName + 杀毒); public VideoFile(String fileName) this.fileName = fileName; Client.javapublic class Client public static void main(String a
23、rgs) AbstractFile file1, file2, file3; Folder folder1, folder2; file1 = new ImageFile(风景); file2 = new TextFile(乔布斯全传); file3 = new VideoFile(尖峰时刻); folder1 = new Folder(总文件夹); folder2 = new Folder(子文件夹); folder2.add(file1); folder2.add(file2); folder1.add(file3); folder1.add(folder2); folder1.killV
24、irus(); 4. 类图: 实现代码:AbstractBranch.javapublic abstract class AbstractBranch public abstract void receiveDoc(); public abstract String getName();AdOffice.javapublic class AdOffice extends AbstractBranch private String name; public void receiveDoc() System.out.println(行政办公室收到文件); public AdOffice(Strin
25、g name) this.name = name; public String getName() return name; EdOffice.javapublic class EdOffice extends AbstractBranch private String name; public void receiveDoc() System.out.println(教务办公室收到文件); public EdOffice(String name) this.name = name; public String getName() return name; Branch.javaimport
26、java.util.ArrayList;public class Branch extends AbstractBranch private ArrayList list; private String name; public Branch(String name) this.name = name; public void receiveDoc() System.out.println(name + 分部收到文件); public AbstractBranch getChild(int n) return list.get(n); public void add(AbstractBranc
27、h abBranch) list.add(abBranch); public void remove(AbstractBranch abBranch) list.remove(abBranch); public String getName() return name; public void sendDoc(AbstractBranch abBranch) System.out.println(name + 分部发送文件到 + abBranch.getName(); abBranch.receiveDoc(); Client.javapublic class Client public st
28、atic void main(String args) AbstractBranch ab1, ab2; Branch b1, b2, b3, b4; ab1 = new AdOffice(行政办公室); ab2 = new EdOffice(教务办公室); b1 = new Branch(北京); b2 = new Branch(湖南); b3 = new Branch(长沙); b4 = new Branch(湘潭); b1.sendDoc(b2); b2.sendDoc(b3); b2.sendDoc(b4); b4.sendDoc(ab1); b3.sendDoc(ab2); 5. 类图: 实现代码:BackUpFacade.j
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1