您好、欢迎来到现金彩票网!
当前位置:盛源彩票app下载 > 构件存储库 >

软件工程课件第七章软件复用与构件技术

发布时间:2019-06-03 11:39 来源:未知 编辑:admin

  软件工程课件第七章软件复用与构件技术._幼儿读物_幼儿教育_教育专区。软件工程课件第七章软件复用与构件技术.

  第七章软件复用和构件技术 7 第七章 软件复用和 构件技术 7.1 软件复用概述 软件复用就是将已有的软件成分用于构造新的软 件系统,以达到提高软件系统的开发质量与效率,降 低开发成本的目的。 可复用的软件成分,也称为可复用构件(Reusable Component) 可从旧软件中提取,也可以专门为复用 而开发。 软件复用不仅是对程序的复用,它包括对软件生 产过程中任何活动所产生的制成品的复用。如:项目 计划、可行性报告、需求定义、分析模型、详细说明、 源程序和测试用例等等。 7.1.1 软件复用的级别 高 测试信息的复用 抽 三种方式复用: 从现有系统的分析结果中提取可复 用构件用于新系统的分析; 主要包括测试用例( test case ) 用一份完整的分析文档作为输入, 的复用和测试过程信息的复用。 成生针对不通软硬件平台和其它实现条 件的多项设计; 独立于具体应用,专门开发一些 可被复用的分析结果是针对问题域 可复用的分析构件。 象 程 度 分析结果的复用 的某些事物或某些问题的抽象程度 更高的解法。 受实际环境影响小,可复用机会多, 所需修改少。 包括目标代码,也包括文本形式的 源代码。 设计结果的复用 低 代码的复用 软件生产过程主要是正向过程 ,即软件产品从抽象 级别较高的形态向抽象级别较低的形态演化 ,所以较高 级别的复用容易带动较低级别的复用,反之则不然。 复用级别越高,可得到的回报也越大,因此分析 软件(Analysis Ware)和设计软件(Design Ware)的复用 备受重视。 软件复用的优点: (1)提高软件生产率,降低软件生产代价; (2)提高软件质量; (3)互操作性好; (4)推动标准化; (5)支持原型开发。 7.1.2软件复用的形式 一、按照重用活动所跨越的应用领域的类型分 1. 横向复用( horizontal reuse ) 也称为水平 复用,是指复用活动的范围跨越了几个不同的应 用领域,复用的软件产品主要包括数据结构、通 用算法、人机界面等软件元素。 2. 纵向复用( vertical reuse ) 也称为垂直复 用,是指复用活动的范围限制在同一个应用领域 或者是一类具有较多共性的应用领域内。 二、基于软件复用的软件开发过程的角度分 1.生产者复用(product reuse) 指建立、获取或者重新设计可复用构件的活动。涉 及到的活动包括:复用的规划、领域分析、构件的开发、 构件库的组织和管理。 2.消费者复用(consumer reuse) 指使用可复用的构件建立新的系统的活动。涉及到 的活动包括:应用系统的规划、构件的检索和选择、应 用系统中非复用部分的开发、应用系统的组装。 生产者复用 (为复用开发构件) 建立构件 消费者复用 (使用构件开发应用) 组装应用 生产者复用与消费者复用 7.1.3 软件复用的困难 复用具有许多明显的优点,目前应用不广泛的主 要原因是: (1)技术因素 构件与应用系统之间的差异; 构件要达到一定的规模,才能支持有效的复用; 发现合用构件的困难; 基于复用的软件开发方法和软件过程需要一些新 的理论、技术及支持环境。 (2)人的因素 喜欢自己创造而不喜欢使用别人的东西。 7.1.3 软件复用的困难 复用具有许多明显的优点,目前应用不广泛的主要 原因是: (3)管理因素 把复用构件和一般软件构件同等看待,把复用看 作可有可无的事。 (4)教育因素 软件科学技术的教育与培训中,缺乏关于软件复用 的内容,缺少专门教材和课程。 7.2 软件构件与构件工程 基于软件构件的软件工程也称为构件工程,是 以面向对象的方法为基础,实现软件重用,构造新 系统的过程。 为了实现软件重用,基于软件构件的软件工程 强调领域工程与软件工程同时进行。 领域工程创建应用领域的模型,标识、构造、 分类和传播一组可重用的软件。 图2 典型的重用的过程模型,描述了领域工程与软件工程的关系。 领域工程 领域分析 设计软件 体系结构 开发可重用 的软件成分 领域 模型 结构 模型 中心库 可重用软件 成分/构件 软件工程 系统分析 用户 需求 规格说明 与设计 建造 系统规 格说明 分析与 设计模型 应用 软件 重用的过程模型 6.2.1 可复用构件 一个软件只有在多个系统中被使用才可称为“可复 用构件”,必须具备的条件: (1)独立性 解决一个相对独立的问题,或大问题中某个相对 独立的部分; (2)完整性 提供较完整的解决,不要遗留很多缺口,让复用 者做大量补充; (3)可标识性 构件所解决的问题应该是可标识的,可命名,有 简要介绍,便于理解和使用。 6.2.1 可复用构件 一个软件只有在多个系统中被使用才可称为“可复 用构件”,必须具备的条件: (4)通用性 构件解决的问题,应在同类应用中具有一般性; (5)适应性 应用场合有某些变化时,构件仍是可用的,使构 件的某些数据参数化和数据类型参数化; (6)可靠性 要求构件对预计将要使用它的系统时可靠的; (7)标准化 可复用构件的标准化对于软件复用是至关重要的。 6.2.2 基于构件的软件工程 基于构件的软件工程与传统的或面向对象的软 件工程相比,有显著的差异。 它不是针对某个特定的软件系统,而是针对一 类软件系统的共同的特征、知识和需求。 基于构件的软件的开发过程包括两个并发的子 过程,一个是领域工程,另一个是基于构件的开 发。领域工程完成一组可复用构件的标示、构造、 分类和传播;基于构件的开发完成使用可复用构件 构造新的软件系统。 7.2.3 领域分析 领域分析是对特定应用领域中共同的特征、知 识、需求的标识、分析和规约。领域分析是特定领 域内软件重用的基础,它的目标就是:发现和挖掘 在特定领域内可以被复用的构件。领域分析活动中 输入和输出如图所示: 输入信息 技术文献 已有应用 专家经验/建议 当前与未来的需求 输出信息 领域分析 领域语言 复用标准 分类方法 功能/行为模型 领域分析的输入和输出 领域分析不是针对某个特定的软件系统,而是针 对一类软件系统的共同的特征、知识和需求。比需求 分析更一般、更抽象、更广泛的特征。 领域分析(Domain Analysis)是对一类应用系统的 共同应用领域进行系统化分析,以发现该领域的共同知 识、需求及其应用系统的共同特征。 领域分析又称领域工程(Domain Engineering), 是软件工程的发展与延伸。 领域分析是一项比系统分析更难的工作。领域分 析方法可采用结构化方法和面向对象方法,而后者将 成为主流。 7.3 构件的开发与构件库 构件的开发 领域分析的结果为构件的选取和开发提供了指导性的原则。 除了有领域分析作为其基础,构件开发还需要遵循一定的设计 概念和原则。 构件应该具有相当的一般性和抽象性,能够用于满足一类 相似的需求,一个过于特殊的构件是很难被重复使用的。即使 一个通用性很高的构件也不可能完全适应用户的需求和运行环 境,所以在一个构件被不同的应用复用时,对它的某些部分进 行修改是不可避免的。所以构件开发时,需要为用户对构件的 调整和修改留出余地。例如继承、参数化、模板和宏都是典型 的提高构件灵活性和可调整性的机制。 7.3.1 构件库 构件库(Component Library)用于对可复用构件进行存 储和管理。它是支持软件复用的必要设施。构件库必须有大 量的可复用构件。 构件库系统应提供的主要功能:构件的存储、管理、检 索以及库的浏览与维护等。 关键是支持使用者高效而准确地发现所需的可复用构件。 相关的主要技术是分类方法和检索方法。 支持方便的、友好的用户管理和使用界面。 涉及两个基本问题: 构件分类 构件检索 7.3.2 构件的分类 大多数的构件分类模式可以归纳为以下三种类型: (1)枚举分类 通过定义一个层次结构来对构件进行分类。构件库中的可 复用构件按照某种标准被分成了若干个大类,而每个大类中的 构件再被划分成若干个小类,依此类推,这样就形成了一个构 件分类的层次结构, 图形用户界面类 窗口类 菜单类 文字窗 口构件 图形窗 口构件 弹出式菜 单构件 普通菜 单构件 系统菜 单构件 枚举分类的层次结构 (2)刻面分类 一个刻面描述构件某一个方面的特征。刻面分类则是从不 同的侧面对构件进行分类,每一种分类方式称为一个刻面。不 同的刻面根据其重要性可以设置不同的优先级。 刻面 应用领域 对象 功能 编程语言 刻面值 图形用户界面编程 菜单 动态修改菜单项 JAVA 对构件的每个刻面赋予相应的值,用以描述该构件。刻面 分类具有较好的灵活性,易于加入新的刻面值,因此刻面分类 比枚举分类更易于扩展和修改。 该方法首先是为构件库中的所有构件定义一组属性,并赋 予相应的属性值。开发人员通过指定一组属性值在构件库中对 构件进行检索。 刻面分类法(Faceted Classification): 支持多重观点对构件进行分类,例如从构件的应用领域、构 件所描述的对象、构件的观点和编程语言等不同的方式来分类。 每一种分类方式称为一个刻面。 每个刻面把构件集合划分为一个子集,各刻面所划分的子集 形成一些较小的交集。 一个构件对每个每个刻面有一个刻面值,例如: 应用领域 = 计算机绘图 对象 = 椭圆 功能 = 彩色填充, 编程语言 = C++ 检索一个构件时,给出一组刻面值,将确定一组子集合, 构件应该在这些子结合的交集中,从其中确认所需的构件就比 较容易。 构件可用属性描述,例如构件类型、开发单位、作者、提 交日期等属性。检索时通过构件的属性可以缩小搜索范围。 刻面和属性都不涉及构件内部实现,只是为了便于构件的 管理、检索和使用。如果把构件比作一只箱子,其内容如同箱 子中装的东西,刻面和属性则如同箱子外边的标签。 刻面分类法可以看作层次分类法的扩充。 (3)属性-值分类 该方法首先是为构件库中的所有构件定义一组属性,并赋 予相应的属性值。开发人员通过指定一组属性值在构件库中对 构件进行检索。 该分类方法与刻面分类方法有几点不同之处: 属性的数量没有限制,而刻面描述一般限制在7或8个刻面; 属性没有优先级,而刻面根据其重要程度,有相应的优先 级; 7.3.3 构件检索 构件库中检索一个构件和在数据库中检索一个记录是不同 的。 构件库检索的不确定性带来两种相互矛盾的结果:检索的 结果可能是一个较大的构件集合,要从中找到所需的构件仍然 很费力;检索得到的集合没有把真正需要的构件包括在内。 解决方法: (一)一般构件库系统能对提出的检索条件作广义解释。 建立同义词对照表,例如“商品销售”、“售货”、“卖 货”看作一组同义词; 建立近意词对照表,例如把“商业”、“商场”、“连锁 店”看作一组近意词。 系统首先匹配同义词,再匹配近意词,都可以被包括到广 义结果集合中。 (二)使检索得到的构件集合尽可能不包括对用户无用的构件。 增加更多的刻面与构件属性:较多的刻面和属性值,将得 到更小的子集合文集,减轻最终发现和确认所需构件的难度; 建立构件关键词:根据构件内容提炼关键词,如同学术论 文的关键词,反映有关构件内容的一些主要信息。 例如,找功能构件的关键词有“压入”、“弹出”、“后 进先出”等等。如果通过刻面和构件属性得到的构件子集较大, 可用关键词作进一步的检索,以缩小搜索范围。 改进构件检索的其它措施: (1)记录用户使用构件库的经验,并根据这些经验改经构 件检索系统; (2)对每个构件给出一段文字的简要介绍; (3)提供较强的人机对线)引导用户对自己需求的表达不断精化。 7.3.4 基于构件的开发 基于构件的开发是使用可复用构件组装开发新的应用系统。 一、开发过程 1、构件的鉴定 构件的鉴定是对打算用于软件开发的构件能否满足应用的 需要,达到应用所需要的性能、可靠性、质量的保证进行相应 的考察。 2、构件的调整 通常在将构件复用到应用中时,构件需要进行必要的调整 和修改才能适应应用的需要。 3、 构件的组装 构件的组装是将经过鉴定和调整以后的构件组装到应用系 统中。通常为了达到此目的,还必须建一个基础设施提供构件 协同的模型和使构件能够交互并完成共同任务的的特定服务。 二、基于构件的软件开发特点 1、开发的质量 基于构件的软件开发的一个明显的优点就是提高了软件的 质量。 可复用的构件在开发过程中,都经过严格的测试。 7.3.5 可复用的软件构架 在同一个领域的应用系统之间,不但可以找到其共同的 软件构件,而且可以发现共同的或相似的软件体系结构 (Software Architecture)。 专向领域的复用开拓了一种新的复用境界,被复用的不 仅是可实现某种局部功能的软件构件,而且可以是一些形成 系统总体结构,并把各个可复用构件连接到一起的软件构架 (Software Framework)。 电子产品的主电路板可看成该产品可复用的构架,它把 许多可复用的电子器件连接在一起。 软件构架是一种由特定领域的软件体系结构所决定的软 件构造框架。 软件构架不是解决软件的某个局部问题,而是描述了软件的 总体结构。它描述了一类软件的总体构成情况,包括该软件有哪 些主要部件以及各部件之间的关系,但是不涉及每个部件的细节。 可复用的软件构架给出一类应用系统在总体构造上的共性或 相似性,忽略了各个系统的局部差异。 例如,一个超级市场的销售管理系统的软件构架,它包括的 类有收款机、商品一览表、商品、供货员、销售事件、帐册和上 级系统接口等。它只表明一般情况下系统应由哪些类构成,并指 出这些类之间的关系。但没有定义每个类,在每个具体情况的系 统中,各个类的内部特征可能是不同的。 在使用这个软件架构和一些构件组装成一个具体的应用 系统时,可以根据该系统的特殊要求选用不同的构件,也可 能对构件做一些局部修改。 可见,软件构架的使用将把软件开发看作一个组装过程, 在软件构架的指导下寻找可复用构件(及开发一些新构件)并 进行组装。 这种基于构件/架构的组装式软件开发过程是目前很受重 视的研究动向。 基于构件/构架的软件开发 基于专向领域的软件复用和领域分析技术,C.Braun等人 在 1993 年 提 出 了 “ 领 域 专 用 软 件 体 系 结 构 ” (DomainSpecific Software Architecture,简称DSSA)的概念。并指 出对基于 DSSA 的软件开发,应采用新的软件生命期观点,研 究符合其特点的软件开发过程。 在领域分析基础上和构件/构架库的支持下进行应用系统 开发,其主要特点是:应用领域中各系统的共同问题已在领 域分析中得到了一般认识,并通过构件、构架的开发统一地 进行了描述和解决。因此,该领域的应用系统开发主要是分 析和解决具体系统中的特殊问题。 所以,一个应用系统的开发不再是从零开始,而是按 照领域构架确定本系统需要哪些可复用构件,根据本系统 的特殊需求对构架和构件进行特殊化,并开发本系统的专 用构件,然后将领域构架、领域构件和系统专用构件组装 成一个完整的系统。 下图是基于构件/构架的软件开发方式的简略表示。 基于构件/构架的软件开发方式

http://nzrimfire.com/goujiancunchuku/258.html
锟斤拷锟斤拷锟斤拷QQ微锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷锟斤拷微锟斤拷
关于我们|联系我们|版权声明|网站地图|
Copyright © 2002-2019 现金彩票 版权所有