软件素养(2)报告-UML与设计模式_第1页
软件素养(2)报告-UML与设计模式_第2页
软件素养(2)报告-UML与设计模式_第3页
软件素养(2)报告-UML与设计模式_第4页
软件素养(2)报告-UML与设计模式_第5页
已阅读5页,还剩6页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、烟台大学计算机与控制工程学院 软件素养(2)烟 台 大 学软件素养(2)大作业题目:_专业: 班级:_姓名: 学号: 指导教师:_成绩:_2016.6.5目录1.UML简述1.1 UML的主要作用Unified Modeling Language (UML)又称统一建模语言或标准建模语言,是始于1997年一个OMG标准,它是一个支持模型化和软件系统开发的图形化语言,为软件开发的所有阶段提供模型化和可视化支持,包括由需求分析到规格,到构造和配置。面向对象的分析与设计(OOA&D,OOAD)方法的发展在80年代末至90年代中出现了一个高潮,UML是这个高潮的产物。它不仅统一了Booch、R

2、umbaugh和Jacobson的表示方法,而且对其作了进一步的发展,并最终统一为大众所接受的标准建模语言。1.2 UML中图的种类UML规范用来描述建模的概念有,类(对象的)、对象、关联、职责、行为、接口、用例、包、顺序、协作,以及状态。UML定义了5种类图,10种模型图,其中使用较为广泛的有用例图和类图。用例图:展示系统外部的各类执行者与系统提供的各种用例之间的关系。类图:展示系统中类的静态结构。1.3 用例图1.4 类图 。2.面向对象设计原则2.1 面向对象的设计原则(1)单一职责原则:一个对象应该只包含单一的职责,并且该职责被完整地封装在一个类中。(2)开闭原则:一个软件实体应当对扩

3、展开放,对修改关闭。也就是说在设计一个模块的时候,应当使这个模块可以在不被修改的前提下被扩展,即实现在不修改源代码的情况下改变这个模块的行为。(3)里氏代换原则:如果对每一个类型为S的对象o1,都有类型为T的对象o2,使得以T定义的所有程序P在所有的对象o1都代换成o2时,程序P的行为没有变化,那么类型S是类型T的子类型。通俗来说,就是所有引用基类(父类)的地方必须能透明地使用其子类的对象。(4)依赖倒转原则:高层模块不应该依赖低层模块,它们都应该依赖抽象。抽象不应该依赖于细节,细节应该依赖于抽象。(5)接口隔离原则:客户端不应该依赖那些它不需要的接口,也就是说,一旦一个接口太大,则需要将它分

4、割成一些更细小的接口,使用该接口的客户端仅需知道与之相关的方法即可。(6)合成复用原则:尽量使用对象组合,而不是用继承来达到复用的目的(7)迪米特法则:每一个软件单位对其他的单位都只有最少的知识,而且局限于那些与本单位密切相关的软件单位。2.2 实例说明2.21 单一职责原则某基于Java的C/S系统的“登录功能”通过如下登录类(Login)实现:现使用单一职责原则对其进行重构:具体代码实现:/*MainClass类*/public class MainClass public static void main(String args) LoginForm lf=new LoginForm()

5、;lf.Display();/*LoginForm类*/public class LoginForm private UserDao dao;public void init() void Display() public void Validate() /*UserDao类*/public class UserDao private DBUtil db;public boolean findUser(String userName, String userPassword) boolean flag = false;return flag;/*DBUtil类*/import java.sql

6、.Connection;public class DBUtil public Connection getConnection() Connection conn = null;return conn;2.22 开闭原则具体代码实现:public class Test interface Light public void shine();/ 抽象类class WhiteLight implements Light public void shine() System.out.println("发白光!");class RedLight implements Light p

7、ublic void shine() System.out.println("发红光!");class LedLight implements Light public void shine() System.out.println("发LED光!");class Base public void test(Light l) l.shine();2.23里氏代换原则具体代码实现public class Test public static void main(String args) Hand hand = new Hand();hand.thing =

8、 new Door();hand.doThing();hand.thing = new Computer();hand.doThing();interface Thing public void doThing();class Door implements Thing public void doThing() class Computer implements Thing public void doThing() class Hand public Thing thing;public void doThing() thing.doThing();3.涉及模式介绍3.1 简单工厂模式3.

9、11 定义简单工厂模式(Simple Factory Pattern)属于类的创新型模式,又叫静态工厂方法模式(Static FactoryMethod Pattern),是通过专门定义一个类来负责创建其他类的实例,被创建的实例通常都具有共同的父类。3.12 模式动机对于系统中的某些类来说,只有一个实例很重要,例如,一个系统中可以存在多个打印任务,但是只能有一个正在工作的任务;一个系统只能有一个窗口管理器或文件系统;一个系统只能有一个计时工具或ID(序号)生成器。3.13 优缺点分析简单工厂模式的优点:工厂类含有必要的判断逻辑,可以决定在什么时候创建哪一个产品类的实例,客户端可以免除直接创建产

10、品对象的责任,而仅仅“消费”产品;简单工厂模式通过这种做法实现了对责任的分割,它提供了专门的工厂类用于创建对象。客户端无须知道所创建的具体产品类的类名,只需要知道具体产品类所对应的参数即可,对于一些复杂的类名,通过简单工厂模式可以减少使用者的记忆量。通过引入配置文件,可以在不修改任何客户端代码的情况下更换和增加新的具体产品类,在一定程度上提高了系统的灵活性。简单工厂模式的缺点:由于工厂类集中了所有产品创建逻辑,一旦不能正常工作,整个系统都要受到影响。使用简单工厂模式将会增加系统中类的个数,在一定程序上增加了系统的复杂度和理解难度。系统扩展困难,一旦添加新产品就不得不修改工厂逻辑,在产品类型较多

11、时,有可能造成工厂逻辑过于复杂,不利于系统的扩展和维护。简单工厂模式由于使用了静态工厂方法,造成工厂角色无法形成基于继承的等级结构。3.2 抽象工厂模式3.21 定义抽象工厂模式(Abstract Factory Pattern):提供一个创建一系列相关或相互依赖对象的接口,而无须指定它们具体的类。抽象工厂模式又称为Kit模式,属于对象创建型模式。3.22 模式动机在工厂方法模式中具体工厂负责生产具体的产品,每一个具体工厂对应一种具体产品,工厂方法也具有唯一性,一般情况下,一个具体工厂中只有一个工厂方法或者一组重载的工厂方法。但是有时候我们需要一个工厂可以提供多个产品对象,而不是单一的产品对象

12、。3.23 优缺点分析抽象工厂模式的优点:抽象工厂模式隔离了具体类的生成,使得客户并不需要知道什么被创建。由于这种隔离,更换一个具体工厂就变得相对容易。所有的具体工厂都实现了抽象工厂中定义的那些公共接口,因此只需改变具体工厂的实例,就可以在某种程度上改变整个软件系统的行为。另外,应用抽象工厂模式可以实现高内聚低耦合的设计目的,因此抽象工厂模式得到了广泛的应用。当一个产品族中的多个对象被设计成一起工作时,它能够保证客户端始终只使用同一个产品族中的对象。这对一些需要根据当前环境来决定其行为的软件系统来说,是一种非常实用的设计模式。增加新的具体工厂和产品族很方便,无须修改已有系统,符合“开闭原则”。

13、抽象工厂模式的缺点:在添加新的产品对象时,难以扩展抽象工厂来生产新种类的产品,这是因为在抽象工厂角色中规定了所有可能被创建的产品集合,要支持新种类的产品就意味着要对该接口进行扩展,而这将涉及到对抽象工厂角色及其所有子类的修改,显然会带来较大的不便。开闭原则的倾斜性(增加新的工厂和产品族容易,增加新的产品等级结构麻烦)3.3 适配器模式3.31 定义适配器模式(Adapter Pattern) :将一个接口转换成客户希望的另一个接口,适配器模式使接口不兼容的那些类可以一起工作,其别名为包装器(Wrapper)。适配器模式既可以作为类结构型模式,也可以作为对象结构型模式。3.32 模式动机适配器提

14、供客户类需要的接口,适配器的实现就是把客户类的请求转化为对适配者的相应接口的调用。也就是说:当客户类调用适配器的方法时,在适配器类的内部将调用适配者类的方法,而这个过程对客户类是透明的,客户类并不直接访问适配者类。因此,适配器可以使由于接口不兼容而不能交互的类可以一起工作。3.33 优缺点分析适配器模式的优点:将目标类和适配者类解耦,增加了类的透明性和复用性,同时系统的灵活性和扩展性都非常好,更换适配器或者增加新的适配器都非常方便,符合“开闭原则”;适配器模式的缺点:适配器类在很多编程语言中不能同时适配多个适配者类,对象适配器模式的缺点是很难置换适配者类的方法。4.详细的类图设计画出该设计代码

15、中的类图结构,注意需要特别说明哪一块使用到了设计模式,使用的是何种模式。(注意使用starUML或者其他专业的UML绘图工具画)5.代码列表将所做大作业的代码罗列出来(代码字体采用Arial Unicode字体,5号字)DBConnection:Import6.个人体会设计模式是一套被反复使用、多数人知晓的、经过分类编目的、代码设计经验的总结。使用设计模式是为了可重用代码、让代码更容易被他人理解、保证代码可靠性。毫无疑问,设计模式于己于他人于系统都是多赢的;设计模式使代码编制真正工程化;设计模式是软件工程的基石脉络,是软件开发过程中不可或缺的部分。使用了设计模式的思想进行编程后,极大的提高了程序代码的复用性,训练了编程开发的结构性的设计能力。通过这次课程设计使我们在巩固了课堂所学知识的基础上,又培养了灵活运用和组合集成所学过知识及

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论