第10章 软件重用技术

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

(二)使检索得到的构件集合尽可能不包括对用户无用的构件。 增加更多的刻面与构件属性:较多的刻面和属性值,将得 到更小的子集合文集,减轻最终发现和确认所需构件的难度; 建立构件关键词:根据构件内容提炼关键词,如同学术论 文的关键词,反映有关构件内容的一些主要信息。 例如,找功能构件的关键词有“压入”、“弹出”、“后 进先出”等等。如果通过刻面和构件属性得到的构件子集较大, 可用关键词作进一步的检索,以缩小搜索范围。 改进构件检索的其它措施: (1)记录用户使用构件库的经验,并根据这些经验改经构 件检索系统; (2)对每个构件给出一段文字的简要介绍; (3)提供较强的人机对话功能; (4)引导用户对自己需求的表达不断精化。
10.3.1 构件库
构件库(Component Library)用于对可重用构件进行存 储和管理。它是支持软件重用的必要设施。构件库必须有大 量的可重用构件。
构件库系统应提供的主要功能:构件的存储、管理、检 索以及库的浏览与维护等。
关键是支持使用者高效而准确地发现所需的可重用构件。 相关的主要技术是分类方法和检索方法。 支持方便的、友好的用户管理和使用界面。 涉及两个基本问题: 构件分类 构件检索
二、基于软件重用的软件开发过程的角度分 1.生产者重用(product reuse) 指建立、获取或者重新设计可重用构件的活动。涉 及到的活动包括:重用的规划、领域分析、构件的开发、 构件库的组织和管理。 2.消费者重用(consumer reuse) 指使用可重用的构件建立新的系统的活动。涉及到 的活动包括:应用系统的规划、构件的检索和选择、应 用系统中非重用部分的开发、应用系统的组装。
10.2.1 可重用构件 一个软件只有在多个系统中被使用才可称为“可重 用构件”,必须具备的条件: (4)通用性 构件解决的问题,应在同类应用中具有一般性; (5)适应性 应用场合有某些变化时,构件仍是可用的,使构 件的某些数据参数化和数据类型参数化; (6)可靠性 要求构件对预计将要使用它的系统时可靠的; (7)标准化 可重用构件的标准化对于软件重用是至关重要的。
对构件的每个刻面赋予相应的值,用以描述该构件。刻面 分类具有较好的灵活性,易于加入新的刻面值,因此刻面分类 比枚举分类更易于扩展和修改。 该方法首先是为构件库中的所有构件定义一组属性,并赋 予相应的属性值。开发人员通过指定一组属性值在构件库中对 构件进行检索。
刻面分类法(Faceted Classification): 支持多重观点对构件进行分类,例如从构件的应用领域、构 件所描述的对象、构件的观点和编程语言等不同的方式来分类。 每一种分类方式称为一个刻面。 每个刻面把构件集合划分为一个子集,各刻面所划分的子集 形成一些较小的交集。 一个构件对每个每个刻面有一个刻面值,例如: 应用领域 = 计算机绘图 对象 = 椭圆 功能 = 彩色填充, 编程语言 = C++
软件重用的优点: (1)提高软件生产率,降低软件生产代价; (2)提高软件质量; (3)互操作性好; (4)推动标准化; (5)支持原型开发。
10.1.2软件重用的形式 一、按照重用活动所跨越的应用领域的类型分 1.横向重用(horizontal reuse)也称为水平 重用,是指重用活动的范围跨越了几个不同的应 用领域,重用的软件产品主要包括数据结构、通 用算法、人机界面等软件元素。 2.纵向重用(vertical reuse)也称为垂直重 用,是指重用活动的范围限制在同一个应用领域 或者是一类具有较多共性的应用领域内。
10.3 构件的开发与构件库
构件的开发 领域分析的结果为构件的选取和开发提供了指导性的原则。 除了有领域分析作为其基础,构件开发还需要遵循一定的设计 概念和原则。 构件应该具有相当的一般性和抽象性,能够用于满足一类 相似的需求,一个过于特殊的构件是很难被重复使用的。即使 一个通用性很高的构件也不可能完全适应用户的需求和运行环 境,所以在一个构件被不同的应用重用时,对它的某些部分进 行修改是不可避免的。所以构件开发时,需要为用户对构件的 调整和修改留出余地。例如继承、参数化、模板和宏都是典型 的提高构件灵活性和可调整性的机制。
6.2.2 基于构件的软件工程
基于构件的软件工程与传统的或面向对象的软 件工程相比,有显著的差异。 它不是针对某个特定的软件系统,而是针对一 类软件系统的共同的特征、知识和需求。 基于构件的软件的开发过程包括两个并发的子 过程,一个是领域工程,另一个是基于构件的开 发。领域工程完成一组可重用构件的标示、构造、 分类和传播;基于构件的开发完成使用可重用构件 构造新的软件系统。
10.3.2 构件的分类
大多数的构件分类模式可以归纳为以下三种类型: (1)枚举分类 通过定义一个层次结构来对构件进行分类。构件库中的可 重用构件按照某种标准被分成了若干个大类,而每个大类中的 构件再被划分成若干个小类,依此类推,这样就形成了一个构 件分类的层次结构,
图形用户界面类
窗口类
菜单类
文字窗 口构件
二、基于构件的软件开发特点 1、开发的质量 基于构件的软件开发的一个明显的优点就是提高了软件的 质量。 可重用的构件在开发过程中,都经过严格的测试。
(3)属性-值分类
该方法首先是为构件库中的所有构件定义一组属性,并赋 予相应的属性值。开发人员通过指定一组属性值在构件库中对 构件进行检索。 该分类方法与刻面分类方法有几点不同之处: 属性的数量没有限制,而刻面描述一般限制在7或8个刻面; 属性没有优先级,而刻面根据其重要程度,有相应的优先 级;
10.3.3 构件检索
10.2.3 领域分析 领域分析是对特定应用领域中共同的特征、知 识、需求的标识、分析和规约。领域分析是特定领 域内软件重用的基础,它的目标就是:发现和挖掘 在特定领域内可以被重用的构件。领域分析活动中 输入和输出如图所示:
输入信息
技术文献 已有应用 专家经验/建议 当前与未来的需求
输出信息
领域分析 领域语言 重用标准 分类方法 功能/行为模型
生产者重用 (为重用开发构件)
建立构件
消费者重用 (使用构件开发应用)
组装应用
生产者重用与消费者重用
10.1.3 软件重用的困难 重用具有许多明显的优点,目前应用不广泛的主 要原因是:
(1)技术因素
构件与应用系统之间的差异;
构件要达到一定的规模,才能支持有效的重用;
发现合用构件的困难; 基于重用的软件开发方法和软件过程需要一些新 的理论、技术及支持环境。
第十章软件重用和构件技术
10
第十章
软件重用技术
10.1 软件重用概述
软件重用就是将已有的软件成分用于构造新的软 件系统,以达到提高软件系统的开发质量与效率,降 低开发成本的目的。 可重用的软件成分,也称为可重用构件(Reusable Component)可从旧软件中提取,也可以专门为重用 而开发。 软件重用不仅是对程序的重用,它包括对软件生 产过程中任何活动所产生的制成品的重用。如:项目 计划、可行性报告、需求定义、分析模型、详细说明、 源程序和测试用例等等。
10.2 软件构件与构件工程
基于软件构件的软件工程也称为构件工程,是 以面向对象的方法为基础,实现软件重用,构造新 系统的过程。 为了实现软件重用,基于软件构件的软件工程 强调领域工程与软件工程同时进行。 领域工程创建应用领域的模型,标识、构造、 分类和传播一组可重用的软件。
图2
典型的重用的过程模型,描述了领域工程与软件工程的关系。
图形窗 口构件
弹出式菜 单构件
普通菜 单构件
系统菜 单构件
枚举分类的层次结构
(2)刻面分类 一个刻面描述构件某一个方面的特征。刻面分类则是从不 同的侧面对构件进行分类,每一种分类方式称为一个刻面。不 同的刻面根据其重要性可以设置不同的优先级。
刻面 应用领域 对象 功能 编程语言 刻面值 图形用户界面编程 菜单 动态修改菜单项 JAVA
领域工程
领域分析 设计软件 体系结构 开发可重用 的软件成分
领域 模型
结构 模型
中心库
可重用软件 成分/构件
软件工程
系统分析 用户 需求
规格说明 与设计
建造
系统规 格说明
分析与 设计模型
应用 软件
重用的过程模型
6.2.1 可重用构件 一个软件只有在多个系统中被使用才可称为“可重 用构件”,必须具备的条件: (1)独立性 解决一个相对独立的问题,或大问题中某个相对 独立的部分; (2)完整性 提供较完整的解决,不要遗留很多缺口,让重用 者做大量补充; (3)可标识性 构件所解决的问题应该是可标识的,可命名,有 简要介绍,便于理解和使用。
领域分析的输入和输出
领域分析不是针对某个特定的软件系统,而是针 对一类软件系统的共同的特征、知识和需求。比需求 分析更一般、更抽象、更广泛的特征。 领域分析(Domain Analysis)是对一类应用系统的 共同应用领域进行系统化分析,以发现该领域的共同知 识、需求及其应用系统的共同特征。 领域分析又称领域工程(Domain Engineering), 是软件工程的发展与延伸。 领域分析是一项比系统分析更难的工作。领域分 析方法可采用结构化方法和面向对象方法,而后者将 成为主流。

程 度
分析结果的重用
的某些事物或某些问题的抽象程度 更高的解法。 受实际环境影响小,可重用机会多, 所需修改少。 包括目标代码,也包括文本形式的 源代码。
设计结果的重用

代码的重用
软件生产过程主要是正向过程,即软件产品从抽象 级别较高的形态向抽象级别较低的形态演化,所以较高 级别的重用容易带动较低级别的重用,反之则不然。 重用级别越高,可得到的回报也越大,因此分析 软件(Analysis Ware)和设计软件(Design Ware)的重用 备受重视。
构件库中检索一个构件和在数据库中检索一个记录是不同 的。 构件库检索的不确定性带来两种相互矛盾的结果:检索的 结果可能是一个较大的构件集合,要从中找到所需的构件仍然 很费力;检索得到的集合没有把真正需要的构件包括在内。 解决方法:
(一)一般构件库系统能对提出的检索条件作广义解释。 建立同义词对照表,例如“商品销售”、“售货”、“卖 货”看作一组同义词; 建立近意词对照表,例如把“商业”、“商场”、“连锁 店”看作一组近意词。 系统首先匹配同义词,再匹配近意词,都可以被包括到广 义结果集合中。
10.3.4 基于构件的开发
基于构件的开发是使用可重用构件组装开发新的应用系统。
一、开发过程
1、构件的鉴定 构件的鉴定是对打算用于软件开发的构件能否满足应用的 需要,达到应用所需要的性能、可靠性、质量的保证进行相应 的考察。 2、构件的调整 通常在将构件重用到应用中时,构件需要进行必要的调整 和修改才能适应应用的需要。 3、 构件的组装 构件的组装是将经过鉴定和调整以后的构件组装到应用系 统中。通常为了达到此目的,还必须建一个基础设施提供构件 协同的模型和使构件能够交互并完成共同任务的的特定服务。
10.1.1 软件重用的级别 三种方式重用:

测试信息的重用 抽
从现有系统的分析结果中提取可重 用构件用于新系统的分析; 主要包括测试用例(test c百度文库se) 用一份完整的分析文档作为输入, 的重用和测试过程信息的重用。 成生针对不通软硬件平台和其它实现条 件的多项设计; 独立于具体应用,专门开发一些 可被重用的分析结果是针对问题域 可重用的分析构件。
(2)人的因素 喜欢自己创造而不喜欢使用别人的东西。
10.1.3 软件重用的困难 重用具有许多明显的优点,目前应用不广泛的主要 原因是:
(3)管理因素 把重用构件和一般软件构件同等看待,把重用看 作可有可无的事。
(4)教育因素 软件科学技术的教育与培训中,缺乏关于软件重用 的内容,缺少专门教材和课程。
检索一个构件时,给出一组刻面值,将确定一组子集合, 构件应该在这些子结合的交集中,从其中确认所需的构件就比 较容易。 构件可用属性描述,例如构件类型、开发单位、作者、提 交日期等属性。检索时通过构件的属性可以缩小搜索范围。 刻面和属性都不涉及构件内部实现,只是为了便于构件的 管理、检索和使用。如果把构件比作一只箱子,其内容如同箱 子中装的东西,刻面和属性则如同箱子外边的标签。 刻面分类法可以看作层次分类法的扩充。
相关文档
最新文档