系统分析师论文集三[5][fjnusindy][pdf].pdf
《系统分析师论文集三[5][fjnusindy][pdf].pdf》由会员分享,可在线阅读,更多相关《系统分析师论文集三[5][fjnusindy][pdf].pdf(13页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、 Vol.16,No.1 2005 Journal of Software 软 件 学 报 1000-9825/2005/16(01)0037 面向软件产品家族的变化性建模方法 邹盛享,张 伟,赵海燕+,梅 宏(北京大学 信息科学技术学院 软件研究所,北京 100871)Modeling Variability in Software Product Family ZOU Sheng-Xiang,ZHANG Wei,ZHAO Hai-Yan+,MEI Hong(Institute of Software,School of Electronics Engineering and Compute
2、r Science,Peking University,Beijing 100871,China)+Corresponding author:E-mail:+86-10-62757670,E-mail:,http:/162.105.203.104/belljointlab/index.jsp Received 2004-06-03;Accepted 2004-07-29 Zou SX,Zhang W,Zhao HY,Mei H.Modeling variability in software product family.Journal of Software,2005,16(1):3749.
3、http:/ Abstract:To accommodate the frequent changes of user requirements and operating environments,software systems have to be much more flexible.Fortunately,modeling variability is just a realistic and efficient approach to controlling variability and implementing software reuse,which does well no
4、t only in identifying and expressing variability,but also in assisting the management of variability evolution.This paper proposes an approach to modeling variability in product family.In this approach,variabilities of system behaviors are modeled through extended use case models,while variabilities
5、 in functionality and quality are captured by feature models,and above all,both the models adopt consistent mechanisms to model variability.Summarily,the whole modeling process of the approach is discussed systematically through a real software family on mobile phone.Key words:software product famil
6、y;variability;use case model;feature model;software reuse 摘 要:用户需求和运行环境的变化增加了软件产品开发、维护和演化的难度.另一方面,如果能对同类软件(比如软件产品家族)的变化性实施有效的控制,则可以极大地促进软件复用,提高软件生产效率和质量.对变化性建模是控制变化性的有效手段,既有助于变化性的识别和规约,又能够提供足够的机制支持变化性的演化.提出了一种面向产品家族的变化性建模方法,以变化性的管理策略为指导,从扩展的用况(use case)模型入手捕获系统行为的变化性,以特征模型来组织功能性需求和质量属性并识别其变化性,两种模型对变
7、化性的建模采用相同的机制.还结合一个实例讨论了产品家族变化性建模的全过程.该研究对产品家族变化性的分析与建模具 Supported by the Key Project of the National Natural Science Foundation of China under Grant No.60233010(国家自然科学基金重点项目);the National Grand Fundamental Research 973 Program of China under Grant No.2002CB312003(国家重点基础研究发展规划(973);the National Natur
8、al Science Foundation for Distinguished Young Scholars of China under Grant No.60125206(国家杰出青年科学基金);the Major Project of Science and Technology Research of Ministry of Education of China under Grant No.MAJOR0214(国家教育部重大资助项目);the National Research Foundation for the Doctoral Program of Higher Educati
9、on of China under Grant No.20010001001(国家教育部博士点基金)作者简介:邹盛享(1977),男,湖南澧县人,硕士,主要研究领域为变化性技术,领域工程;张伟(1978),男,博士生,主要研究领域为领域工程,软件构件技术,软件复用;赵海燕(196),女,博士,讲师,主要研究领域为软件复用,数据挖掘;梅宏(1963),男,博士,教授,博士生导师,主要研究领域为软件工程,软件复用,软件构件技术,分布对象技术.38 Journal of Software 软件学报 2005,16(1)有一定的参考作用.关键词:软件产品家族;变化性;用况模型;特征模型;软件复用 中图
10、法分类号:TP311 文献标识码:A 软件复用被认为是解决软件危机、实现软件产业工业化生产方式的有效途径1.软件复用活动包含两个相关的阶段:可复用软件资产的生产阶段(development for reuse)和基于可复用软件资产的应用系统开发阶段(development with reuse)2.领域工程对应于可复用软件资产的生产阶段,即系统地识别、开发和组织领域可复用软件资产,为后期的应用系统开发提供必备的物质和技术基础.软件产品家族方法即是应用软件复用的相关原理和技术,把整个产品家族作为同一问题空间来看待的软件开发方法.这里的产品家族是指一类共享体系结构、特征、代码、构件、中间件或者需求
11、的软件产品3,4.研究和实践表明,由于很好地应用了软件复用技术,软件产品家族方法极大地节省了软件产品的开发成本和时 间5,6,软件产品家族方法也因此被认为是一种提高软件开发效率和控制软件复杂性的有效措施,因而在软件产业界得到越来越多的重视3.产品家族方法要实现对软件复用以及对家族产品演化的支持,必须支持对变化性的有效管理.类比于软件复用的基本过程,产品家族方法过程也可分为两个基本的阶段,即:生产家族核心资产的阶段和根据家族核心资产生产单个产品的阶段.通常,对变化性的识别、设计和实现主要体现在第 1 阶段,第 2 阶段则要对变化性进行定制、配置、绑定等.在家族核心资产的生产过程中,采用怎样的模型
12、来组织核心资产以及对变化性进行控制和管理一直是一个备受关注的问题7,8.Parnas 在 20 世纪 70 年代提出了模块化和信息隐藏两大原则来避免软件中不同成分之间不必要的耦合关系,使得系统中的成分可以相对独立地发生变化9.20 世纪 90 年代,Keepence 提出了一种面向对象的家族模型,用预定义的模式来建模产品家族内的变化性,但这种模型只是在详细设计阶段的解决方案6.另一方面,Will Tracz 在 1990 年提出了一种基于特定领域的体系结构来捕获产品家族的共性的方法,该方法能够很好地组织核心资产,但对变化性的支持却讨论不多10.Zhang 和 Jarzabek 改进了 Bass
13、ett 的框架技术(frame technology)11,提出了 XVCL(XML-based variant configuration language)方法来处理变化点12,13;Becker 提出的变化性规约语言 VSL(variability specification language)7,14也是基于 Bassett 的框架技术.XVCL 和 VSL 都是基于 XML 的配置语言,具有很高的灵活性和抽象性,但这种纯文本化且不直观的变化性处理机制给理解带来了一定的障碍.1990年,Kang提出了面向特征的领域分析方法 FODA.FODA用特征来对需求进行模块化组织,用特征和特征之
14、间的关系来对整个产品领域进行建模15.在此后的领域工程或者产品家族方法研究中,包括 FORM16,PLP17等,都采用了面向特征的领域需求组织方式.然而,仅仅用特征模型来建模整个家族的变化性存在一定的局限性,主要表现在特征模型不能很好地支持对软件产品外在行为的变化性建模.针对以上局限,Griss 等人引入了用况模型,把它与特征模型相结合来对产品家族进行建模,提出了FeatuRSEB 方法18.用况模型在有效地捕获系统功能性需求的同时,还能详细描述用户与系统的交互过程,而且用况模型简单易行,这些特点很好地弥补了仅用特征模型建模的不足.但 FeatuRSEB 方法中提到的用况模型还是传统的用况模型
15、,对系统行为的变化性难以提供有效的表示机制19,20;而且 FeatuRSEB 方法涉及到太多的视图,使建模过程过于繁琐.根据以上分析,本文在现有特征模型和用况模型的基础上,以变化性的管理策略为指导,提出了一种组合的产品家族变化性建模方法.该方法首先从扩展的用况模型入手描述家族系统行为的变化性,然后以特征模型系统化地组织产品家族的功能性需求和质量属性并识别其变化性,同时,在这两种模型中采用相同的机制建模变化性,保证两种模型间的一致性.本文第 1 节主要介绍有关变化性的一些基本概念.第 2 节首先介绍本文对变化性的管理策略,然后详细论述产品家族中控制变化性的两个模型:扩展的用况模型和特征模型,并
16、给出了变化性建模的基本步骤.第 3 节介绍建模变化性的相应支持工具以及一个手机软件产品家族的建模实例.最后对全文进行总结并对下一步的工作进行展望.邹盛享 等:面向软件产品家族的变化性建模方法 39 1 有关变化性 本节首先介绍通常讨论变化性时所涉及的几个术语,包括软件产品线(software product line)、软件产品家族(software product family)和领域(domain),并对它们作一些辨析,然后在此基础上对变化性的定义、变化性的模式和生命周期等进行论述.1.1 软件产品线、产品家族和领域 软件产品线是指针对特定市场区域、具有一组共性特征、从预先生产的核心资产开
17、发而来的软件产品的集合21.软件产品线源于工业界产品线的概念,关注于一个软件企业如何组织一组相似产品的生产.产品家族则是指一类共享体系结构属性、特征、代码、构件、中间件或者需求的软件产品3,4,主要强调产品所在家族的共性,并不限于特定的软件企业.但有些研究对二者并不作严格区分12.软件产品线和产品家族的共同之处在于它们都应用软件复用的相关原理与技术,都可以对应于软件复用过程的领域工程和应用工程两个阶段.领域是指一组具有相似和相近软件需求的应用系统所覆盖的功能区域22.领域可以看成 4 种成分的结合体:商务范围、问题集合(问题空间)、应用系统的集合(解空间)以及共用术语组成的知识集23.领域和软
18、件产品线两者也是比较相近的.有研究者认为,它们的区别只在于领域是由一些概念性的术语组成,而产品线则是包含将要开发的具体的软件产品23.也有研究者认为,二者的不同之处仅仅在于术语使用习惯的差异,学术研究人员通常使用“领域”,而软件项目经理等人员更易于接受“产品线”24.本文讨论的变化性建模方法并不对软件产品线、产品家族和领域这 3 个术语作严格区分,该方法同样可以应用于软件产品线和领域工程中.1.2 变化性 在产品家族方法和领域工程中,变化性都是相对于共性而言的,共性是产品家族存在的基础,而家族内单个产品间的区别则属于变化性.从软件开发人员的角度来看,认定变化性意味着在软件生命周期中把决策延迟到
19、某一个特定的时间阶段,即变化性的绑定时间(binding time).典型的绑定时间包括定制时刻、编译时刻、链接时刻、装载时刻和运行时刻等.1.3 变化点(variation point)和变化点的属性 变化性通常关联在某个变化点上,每个变化点上都包含一个或一组相关的变量(variant)待确定,每个变量都是实现变化性的一种特定方式,它们指出了变化性的取值范围.在开发过程中,变量根据需要可以继续增加或者减少.根据变化点的变量是否固定可以区分变化点的两种类型:开放型(open)或封闭型(closed).如果该变化点的变量能被继续增添、删减或修改,则称该变化点是开放的,否则是封闭的.在一个产品的生
20、命周期中,变量取值必须在其对应的绑定时间之前(包含绑定时间)被固定下来.变化点的绑定时间越晚,产品的灵活性和适应能力就越高.1.4 变化性模式(pattern)和生命周期 变化性模式是指常见的变化性表现形式,最基本的模式有 3 种:可选(optional)、多选一(alternative)和多选多(multiple parallel).可选模式表示变化点上仅有一个变量,有待于最终决定是否绑定;多选一模式是指变化点上有一组相关的变量,而且最后只会选择其中之一绑定;多选多模式意味着在一组变量中,可以同时绑定一个以上的变量.另外还有可选的多选一(optional alternative)、可选的多选
21、多(optional multiple parallel)等模式,它们可由基本模式组合而成.变化性的生命周期是以体现变化性的变化点为观察对象,从该变化点处于隐含状态一直到最后的绑定状态为止所经历的几个阶段.完整的变化性的生命周期包括 6 个阶段,分别是变化性的识别、变化性的分析与设计、变化性的实现、变化性的定制、变化性的配置以及变化性的绑定.其中,前 3 个阶段的活动在家族核心资产的生产过程中完成,后 3 个阶段的活动则在单个应用系统的开发过程中完成.另外,变化性还可能会发生演化,这可能有两方面的原因,一是变化点的取值变量会发生变化,二是变化性所在的产品家族或应用环境发生变化 40 Journ
22、al of Software 软件学报 2005,16(1)也能引起变化性演化.变化性的演化可能需要重新进行变化性的分析、设计和实现等活动.2 软件产品家族的变化性建模 可以从时间和空间的两个维度来刻画变化性:时间上的变化性是指同一产品随着时间的推移在功能或质量属性上发生变化,也可以指同一产品在不同运行时刻根据不同的设置在功能或质量上发生变化;空间上的变化性,即家族中产品间的区别,是指同一时间针对不同客户或市场,产品具有的不同配置.时间上的变化性与空间上的变化性是相互独立而又密切相关的,时间上的变化性也可以通过同一产品不同版本的差异来体现.关注时间上的变化性主要是为了解决产品的演化问题,而关注
23、空间上的变化性则主要是为了解决核心资产的复用 问题.本文中论述的变化性建模方法以变化性的管理策略为指导,以用况模型为起始,以特征模型为中心,从用况和特征两个角度来组织家族核心资产,识别变化性.两种模型对变化性采用相同的建模和约束机制,对产品间的差异(即空间上的变化性)明确标识.2.1 变化性的管理策略 本文的变化性管理策略是指针对变化性生命周期的各个阶段提出相应的对策来实现对变化性的控制:(a)在变化性的识别阶段,需要把变化点识别出来.本文主要采用在用况建模过程中识别具有变化性的用况,以及在特征建模时识别具有变化性的特征的手段识别变化点;(b)在变化性的分析与设计阶段,首先需要识别变化性的模式
24、,再确定变化点的各个变量值以及它们之间的关系,最后还要决定变化点的绑定时间等.我们的两种模型采用相同的变化性建模机制:在图形表达上,用图元变体表达变化性的可选模式,用维度(dimension)-值(value)25组织其他变化性模式,并用命题逻辑来表达它们之间的相互依赖、互斥关系.(c)在变化性的实现阶段,要利用各种变化性的实现技术,在详细设计甚至是编码阶段完成对变化性的控制.比如 Michialis26提出的聚合(aggregation)/代理(delegation)、继承(inheritance)、重载(overloading)、框架技术(frames)、反射技术(reflecion)、设
25、计模式(design pattern),或者是 Mikael 提出的可选的体系结构构件(optional architecture component)、常量条件(condition on constant)、变量条件(condition on variable)等技术27.(d)在变化性的定制阶段,依据变化性在产品家族中所受的限制关系来对变化性进行定制.定制变化性伴随着对产品家族模型的剪裁而发生,一般是对变化点的变量值进行删减.(e)在变化性配置阶段,根据单个应用系统的特性,并结合变化性的定制结果来对已实现的变化性进行配置或作部分调整和修改,以符合此应用系统的需要.(f)在变化性的绑定阶段,
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- fjnusindy pdf 系统分析 论文集
限制150内