已阅读5页,还剩11页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
logo软件工程小论文题目软件设计专业班级: 小组成员: 授课教师: 完成时间: xx 年x月x日 xxxx学院软件工程小论文软件设计目录摘要1引言2第一章 软件设计概述31.1 软件设计定义31.2 设计要素31.3 设计原则31.4 设计过程41.5 指导方针41.6 设计基础5第二章 设计方法62.1 模块设计62.2 数据设计62.3 体系设计7第三章 框架设计73.1 瀑布模型73.1.1 概述73.1.2 瀑布模型优缺点83.1.3 客户需求83.2 增量模型93.2.1 概述9图3-2 增量模型103.2.2 增量模型优缺点10小结11个人感想11参考文献13摘要软件设计是把许多事物和问题抽象起来,并且抽象它们不同的层次和角度。建议用数学语言来抽象事务和问题,因为数学是最好的抽象语言,并且它的本质就是抽象。将复杂的问题分解成可以管理的片断会更容易。将问题或事物分解并模块化这使得解决问题变得容易,分解的越细模块数量也就越多,它的副作用就是使得设计者考虑更多的模块之间耦合度的情况。关键字:抽象语言 模块化 耦合度引言软件设计方法论的这套基本原理已经经过了多年的进化,在软件开发的生命周期中,软件设计是在软件描述提供的的基础上,对软件需求进行分析以形成软件内部结构的描述说明的活动之一。耦合和内聚是两个用来评估软件设计质量的方法。每种概念的影响程度不尽相同,但它们都经历了时间的洗礼。基于这些基本原理设计者可以采用更多更成熟的设计方法。第一章 软件设计概述1.1 软件设计定义软件设计即应用各种各样的技术和原理,并用它们足够详细的定义一个设备、一个程序或系统的物理实现的过程。”对任意的工程产品或系统,开发阶段绝对的第一步是确定将来所要构建的制造原型或实体表现的目标构思。这个步骤是由多方面的直觉与判断力来共同决定的。这些方面包括构建类似模型的经验、一组引领模型发展的原则、一套启动质量评价的标准、以及重复修改直至设计最后定型的过程本身。计算机软件设计与其他工程学科相比还处在幼年时期,仍在不断变化中,例如更新的方法、更好的算法分析、以及理解力的显著进化。软件设计的方法论的出现也只有三十年多一点,仍然缺乏深度、适应性和定量性质,通常更多的与经典工程设计学科相联系。尽管如此,现今的软件技术已经存在、设计质量的标准也可使用、设计符号亦可以应用。软件设计是一种在设计者计划中通过诸如软件如何满足客户的需要,如何才能容易地实现和如何才能方便地扩展功能以适应新的需求等不同的考虑的创造性活动。软件设计有很多设计方法或技巧,通过借鉴他人的经验让这件事完成得更好。同时,设计者们也可以利用成熟的标记法将他们的想法和计划传达给开发者以及其他相关人员,使他们更好地了解这个系统。带着这些意见,我们一起来看看什么有助于程序员们找到他们的软件涅盘。1.2 设计要素软件设计包括软件的结构设计,数据设计,接口设计和过程设计。结构设计是指:定义软件系统各主要部件之间的关系。数据设计是指:将模型转换成数据结构的定义。接口设计是指:软件内部,软件和操作系统间以及软件和人之间如何通信。过程设计是指:系统结构部件转换成软件的过程描述。 1.3 设计原则(1).设计对于分析模型应该是可跟踪的:软件的模块可能被映射到多个需求上。(2).设计结构应该尽可能的模拟实际问题。(3).设计应该表现出一致性。(4).不要把设计当成编写代码。(5).在创建设计时就应该能够评估质量。(6).评审设计以减少语义性的错误。(7).设计应该模块化,将软件逻辑地划分为元素或子系统,并包含数据、体系结构、接口和构件的清晰表示。 1.4 设计过程软件的设计是一个将需求转变为软件陈述(表达)的过程。这种陈述给一个对软件的全局观点。系统通过逐步求精使得设计陈述逐渐接近源代码。这里有两个基本步骤;第一步是初步设计 Preliminary design ,关注于如何将需求转换成数据和软件框架。第二步是详细设计Detail design ,关注于将框架逐步求精细化为具体的数据结构和软件的算法表达。发生中的设计行为、数据、算法和程序设计都需要由现代程序所需的界面设计这一清晰的行为来结合起来。界面设计Interface design建立程序布局和人机交互机制。贯穿设计过程的质量由一系列的正式技术评定formal technical reviews或设计排演 design walkthroughs来评价。 1.5 指导方针(1).设计应该展现层次结构使得软件各部分之间的控制更明智。(2).设计应当模块化;这就是说,软件应在逻辑上分割为实现特定的功能和子功能的部分。(3).设计应当由清晰且可分离的数据和过程表达来构成。(4).设计应使得模块展现独立的功能特性。(5).设计应使得界面能降低模块之间及其与外部环境的连接复杂性。(6).设计应源自于软件需求分析期间获得的信息所定之可重复方法的使用。要拥有良好的设计特征不是靠碰运气,而在设计过程中通过综合运用基础设计原理、系统方法论、彻底的评定回顾可以有助于良好的设计。软件设计方法每天都在进化,作为已经经过测试和细化的方法,良好的设计应具有以下的四种特性,并在所有这些特性之间保持一致。A.将信息领域的表达转换为软件设计的表达的机制。B.表示功能组件及其界面的符号。C.逐步求精和分割的试探。D.质量评估的指导方针。开发软件的时候,不管采用何种设计方法您必须能够熟练运用一套关于数据、算法和程序设计的基本原理。(7).设计应该导出降低模块和外部环境间复杂连接的接口。 1.6 设计基础抽象Abstraction在最高层次上指的是使用待解决的问题领域内的术语描述的解决方案。相对较低层次的抽象则更多的面向程序语言,最低层的抽象则是解决方案的可直接实现的方式描述。软件设计的每一个步骤都是对相应层次解决方案的抽象的逐步求精。求精 Refinement 又叫做逐步求精指的是通过程序细节连续细化来开发程序体系的策略。分步骤的对程序抽象进行分解直至成为编程语言的过程同时造就了程序的层次结构。在这一点上要对细节多做考虑,这也展示了求精实际上是个苦心经营的过程。模块化 Modularity 指的是软件可被分割为分别命名并可寻址的组件(也叫做模块),将模块综合起来又可以满足问题的需求的性质。“软件的模块化是允许智能化管理程序的唯一属性。”换句话说,当您将一个复杂问题分解为一些小问题时会更容易解决。需要重点解释的是即使一个系统必须象“单片机”一样来实现,它也可以采用模块化设计。软件体系(架构)Software Architecture涉及到程序的两个重要特性:1)模块的层次结构。 2)数据结构 。这源自于需求分析时将真实世界问题的含蓄定义与软件解决方案的要素关联起来的分割过程。当问题的每个部分通过一个或多个软件要素得到解决后,与问题的定义和解决相一致软件和数据结构的进化就开始了。这个过程代表了软件的需求分析和设计之间的位置。控制层级Control Hierarchy也称作程序结构,描述程序组件的组织并意味着控制层级。它并不描述软件的程序方面,比如进程顺序、决定的事件/命令、或工作循环。数据结构Data structure描述了单个数据间的逻辑关系。数据结构规定了数据的组织、访问方法、关联程度、和信息的选择处理。数据结构的组织和复杂性只受限于设计者的灵活性。唯一的限制就是经典数据结构的数量阻碍了更多的久经考验的结构出现。软件程序Software Procedure着重于处理每个模块的细节并必须提供一个精确的处理规范,包括事件顺序、准确的判定点、重复操作、甚至数据结构。软件的程序表现是分层的,处理方法应该包括其所有子模块的参考。信息隐藏Information Hiding的法则建议 由设计决定所刻划的模块特性应该对其余的模块不可见 。换句话说,模块应被设计和指定为包含在模块内部且其他模块不可访问的内容对其他模块来说是无需的。隐藏意味着有效的模块性能够通过定义一套独立的模块来实现,这些模块相互之间的通信仅仅包括实现软件功能的所必须的信息。将使用信息隐藏作为设计标准在测试或今后的维护期间需要修改系统时带来了最大的好处。第二章 设计方法设计过程中用以促成模块化设计的四个区域:模块、数据、体系 和程序设计。2.1 模块设计模块设计减低了复杂性、便于修改、且使得支持系统不同部分的并行开发实现起来更容易。模块类型提供的操作特性通过结合时间历史、激活机制、和控制模式来表现。在程序结构内部,模块可以被分类为:(1).顺序 sequential模块,由应用程序引用和执行,但不能从表观上中断。(2).增量 incremental模块,可被应用程序先行中断,而后再从中断点重新开始。 (3).并行 parallel 模块,在多处理器环境下可以与其他模块同时执行。单独的模块更容易开发,因为功能可以被划分出来,而界面只是用来确保功能的独立。功能的独立性可以使用两个定性的标准来衡量: 凝聚性 cohesion 衡量模块的功能强度的相关性,和耦合性 coupling 衡量模块间的相互依赖的相关性。2.2 数据设计 数据设计Data design首先并且有些人也坚信,是最重要的设计行为。数据结构的影响和程序上的复杂性导致数据设计对软件质量有着深远的影响。这种质量由以下的原理来实施:(1).适用于功能和行为分析的系统分析原理同样应该适用于数据。(2).所有的数据结构,以及各自所完成的操作都应该被确定。(3).创建数据词典并用来详细说明数据和程序的设计。(4).底层的数据设计决定应该延迟至设计过程的后期。(5)数据结构的陈述(具体说明)应该只被那些直接使用包含在此结构内的数据的模块所知道。(6).用的数据结构和操作库可以在适当的时候使用。(7).软件设计和编程语言应该支持抽象数据类型的规范和实现。2.3 体系设计体系设Architectural Design的主要目标是开发模块化的程序结构并表达出模块间的控制相关性。另外,体系设计融合了程序结构与数据结构,以及使得数据得以在程序中流动的界面定义。这种方法鼓励设计者关注系统的整体设计而不是系统中单独的组件。选用不同的方法会采用不同的途径来接近体系的原点,但所有这些方法都应该认识到具有软件全局观念的重要性。程序设计Procedural Design在数据、程序结构、和陈述详细算法的说明都已使用类似英语的自然语言来呈现后,再确定程序设计。使用自然语言来陈述的原因是当开发小组的绝大多数成员使用自然语言来交流的话,那么小组外的一个新手在不经学习的情况下会更容易理解这些说明。这里有个问题:程序设计必须毫无歧义的来详细说明程序,但我们都知道不含糊的自然语言也就不自然了。第三章 框架设计为了获得高质量的软件所需要完成的一系列的任务框架,它规定了完成各项任务的工作步骤。3.1 瀑布模型3.1.1 概述1970年温斯顿罗伊斯(Winston Royce)提出了著名的“瀑布模型”,直到80年代早期,它一直是唯一被广泛采用的软件开发模型。瀑布模型是最早出现的软件开发模型,在软件工程中占有重要的地位,它提供了软件开发的基本框架。其过程是从上一项活动接收该项活动的工作对象作为输入,利用这一输入实施该项活动应完成的内容给出该项活动的工作成果,并作为输出传给下一项活动。同时评审该项活动的实施,若确认,则继续下一项活动;否则返回前面,甚至更前面的活动。对于经常变化的项目而言,瀑布模型毫无价值。(采用瀑布模型的软件过程如图所示)图3-1 瀑布模型3.1.2 瀑布模型优缺点1. 优点1) 为项目提供了按阶段划分的检查点。2) 当前一阶段完成后,您只需要去关注后续阶段。3) 可在迭代模型中应用瀑布模型。增量迭代应用于瀑布模型。迭代1解决最大的问题。每次迭代产生一个可运行的版本,同时增加更多的功能。每次迭代必须经过质量和集成测试。2. 缺点1) 在项目各个阶段之间极少有反馈。2) 只有在项目生命周期的后期才能看到结果。3) 通过过多的强制完成日期和里程碑来跟踪各个项目阶段。4)瀑布模型的突出缺点是不适应用户需求的变化3.1.3 客户需求尽管瀑布模型招致了很多批评,但是它对很多类型的项目而言依然是有效的,如果正确使用,可以节省大量的时间和金钱。对于您的项目而言,是否使用这一模型主要取决于您是否能理解客户的需求以及在项目的进程中这些需求的变化程度,对于经常变化的项目而言,瀑布模型毫无价值,对于这种情况,您可以考虑其他的架构来进行项目管理,比如名为螺旋模型(spiral model)的方法。在瀑布模型中,软件开发的各项活动严格按照线性方式进行,当前活动接受上一项活动的工作结果,实施完成所需的工作内容。当前活动的工作结果需要进行验证,如果验证通过,则该结果作为下一项活动的输入,继续进行下一项活动,否则返回修改。瀑布模型强调文档的作用,并要求每个阶段都要仔细验证。但是,这种模型的线性过程太理想化,已不再适合现代的软件开发模式,几乎被业界抛弃,其主要问题在于:1) 各个阶段的划分完全固定,阶段之间产生大量的文档,极大地增加了工作量; 2)由于开发模型是线性的,用户只有等到整个过程的末期才能见到开发成果,从而增加了开发的风险;3) 早期的错误可能要等到开发后期的测试阶段才能发现,进而带来严重的后果。 按照瀑布模型的阶段划分,软件测试可以分为单元测试,集成测试,系统测试。3.2 增量模型3.2.1 概述增量模型融合了瀑布模型的基本成分(重复应用)和原型实现的迭代特征,该模型采用随着日程时间的进展而交错的线性序列,每一个线性序列产生软件的一个可发布的“增量”。当使用增量模型时,第1个增量往往是核心的产品,即第1个增量实现了基本的需求,但很多补充的特征还没有发布。客户对每一个增量的使用和评估都作为下一个增量发布的新特征和功能,这个过程在每一个增量发布后不断重复,直到产生了最终的完善产品。增量模型(incremental model)与原型实现模型和其他演化方法一样,本质上是迭代的,但与原型实现不一样的是其强调每一个增量均发布一个可操作产品。早期的增量是最终产品的“可拆卸”版本,但提供了为用户服务的功能,并且为用户提供了评估的平台。图3-2 增量模型3.2.2 增量模型优缺点1.特色增量模型的特点是引进了增量包的概念,无须等到所有需求都出来,只要某个需求的增量包出来即可进行开发。虽然某个增量包可能还需要进一步适应客户的需求并且更改,但只要这个增量包足够小,其影响对整个项目来说是可以承受的。2.优点采用增量模型的优点是人员分配灵活,刚开始不用投入大量人力资源。如果核心产品很受欢迎,则可增加人力实现下一个增量。当配备的人员不能在设定的期限内完成产品时,它提供了一种先推出核心产品的途径。这样即可先发布部分功能给客户,对客户起到镇静剂的作用。此外,增量能够有计划地管理技术风险。3. 缺点1) .由于各个构件是逐渐并入已有的软件体系结构中的,所以加入构件必须不破坏已构造好的系统部分,这需要软件具备开放式的体系结构。2) .在开发过程中,需求的变化是不可避免的。增量模型的灵活性可以使其适应这种变化的能力大大优于瀑布模型和快速原型模型,但也很容易退化为边做边改模型,从而使软件过程的控制失去整体性。3) .如果增量包之间存在相交的情况且未很好处理,则必须做全盘系统分析,这种模型将功能细化后分别开发的方法较适应于需求经常改变的软件开发过程。小结个人感想曾听老师说过,如果,某个科目的结束了,你做了一个课程设计或者小论文,只要是认真完成了。那么你对这门课至少掌握了70%。写完这个小论文,我深有感触。曾经认为,软件就是写程序,一个软件工作组就是由程序员组成。在这次写小论文的过程中,我了解到软件工程对于软件设计的重要性,因为软件是为了给用户使用而研发的,所以这其中必须有用户的需求分析,当知道开发方向后,还要知道这其中可能出现的问题,以及怎样解决这些问题。之后就要设计出这个程序的大体框架,然后再写出程序,经过调试,纠错后交付使用。后期需要大量的维护。也许就像不了解软件的人永远想不通软件为什么要跟新一样,没有学过软件工程的人,是很难写出一个软件的,他们写出的只是程序,而不是一个可以使用的软件。段晓强 1032104108经过课程设计这段时间老师地教诲和自己地努力,我发现了自己的不足,积累了一些经验。我们在学习的过程中对自己要有信心。一个人能力发挥的程度并不完全取决于周围环境,而在很大程度上决定于自身的努力。我们在学习的过程中不能只学而不去总结归纳。当然,在总结中,随着新旧知识不断地融合与相撞,同时也会产生新的东西,启发人的大脑,从而不断地创新,丰富学习内容。创新是在一定的学习积累的基础上的,因此,它不仅要求我们只学会现有的知识,更重要地是创新,这样
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 9、2025年度绿色建筑模板单项劳务分包合同3篇
- 个人宅基及房屋销售协议版B版
- 2025版门面租赁合同签订流程及注意事项4篇
- 游戏化教学增强小学生注意力的教育模式
- 2025版化妆品销售代理合同范本6篇
- 美容院与互联网平台2025年度线上推广服务合同4篇
- 智能化学习环境下的学生思维升级
- 二零二五年度汽车美容服务合同范本4篇
- 科技产品的动态视觉设计实践分享
- 时间管理对学习态度的积极影响
- 教师招聘(教育理论基础)考试题库(含答案)
- 2024年秋季学期学校办公室工作总结
- 铺大棚膜合同模板
- 长亭送别完整版本
- 智能养老院视频监控技术方案
- 你比我猜题库课件
- 无人驾驶航空器安全操作理论复习测试附答案
- 建筑工地春节留守人员安全技术交底
- 默纳克-NICE1000技术交流-V1.0
- 蝴蝶兰的简介
- 老年人心理健康量表(含评分)
评论
0/150
提交评论