ImageVerifierCode 换一换
格式:DOCX , 页数:23 ,大小:271.60KB ,
资源ID:9246654      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/9246654.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(设计模式实验四DOC.docx)为本站会员(b****7)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

设计模式实验四DOC.docx

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