组件化软件工程课件.ppt
《组件化软件工程课件.ppt》由会员分享,可在线阅读,更多相关《组件化软件工程课件.ppt(59页珍藏版)》请在三一办公上搜索。
1、组件化软件工程,26、我们像鹰一样,生来就是自由的,但是为了生存,我们不得不为自己编织一个笼子,然后把自己关在里面。博莱索27、法律如果不讲道理,即使延续时间再长,也还是没有制约力的。爱科克28、好法律是由坏风俗创造出来的。马克罗维乌斯29、在一切能够接受法律支配的人类的状态中,哪里没有法律,那里就没有自由。洛克30、风俗可以造就法律,也可以废除法律。塞约翰逊,组件化软件工程组件化软件工程26、我们像鹰一样,生来就是自由的,但是为了生存,我们不得不为自己编织一个笼子,然后把自己关在里面。博莱索27、法律如果不讲道理,即使延续时间再长,也还是没有制约力的。爱科克28、好法律是由坏风俗创造出来的。
2、马克罗维乌斯29、在一切能够接受法律支配的人类的状态中,哪里没有法律,那里就没有自由。洛克30、风俗可以造就法律,也可以废除法律。塞约翰逊高级软件工程构件化软件开发陈宁江2008.052软件复用(reuse)的概念软件复用:利用已有的软件来建造新的软件系统的过程,将可复用构件作为新系统的构建模块并以可控的方式和过程对构件进行组合与修改软件复用的发展子程序(Subroutine)(A.Turing,20世纪40年代)复用 代码、函数、算法等“软件工厂”(Mcllroy,1968)软件库、类库构件3,6,复用的一般过程,软件组织了解和评估实施复用的能力,分析复用所带来的收益和所付出的代价,分析已有
3、软件,寻找、评价和选择可复用的软件构件,了解防碍复用的问题,减少复用的风险和代价,确定项目复用过程中各个参与者的职责,扩展或者整合可复用构件库,建立系统性的复用过程,标识某一领域多个应用的共同需求,根据复用需要调整组织结构和软件开发过程,建立制度性的复用,7,复用的层次,8,基于构件的软件开发目标,长期以来的软件开发状况多数软件都是针对某个具体的应用系统从头进行开发的导致:出现了大量的同类软件重复开发,造成大量人力、财力的浪费,而且软件的质量也不高对比:汽车工业的生产模式在已有的部件基础上通过组装进行生产:有专门的部件生产工厂,汽车设计者在设计中选择市场上已有的合适的部件避免了大量的重复劳动,
4、提高了产品质量和生产效率,促进分工合作我们的目标:将制造业中的组装式生产模式引入到软件开发中,9,构件(Component)的典型定义,Pressman:构件是某系统中有价值的、几乎独立的并可替换的一个部分,它在良好定义的体系结构语境内满足某清晰的功能Brown:构件是一个独立发布的功能部分,可以通过其接口访问它的服务“计算机科学技术百科全书”:软件构件是软件系统中具有相对独立功能,可以明确标识,接口由规约指定,与语境有明显依赖关系,可独立部署,且多由第三方提供的可组装软件实体;软件构件须承载有用的功能,并遵循某种构件模型;可复用构件是指具有可复用价值的构件,10,构件(Component)的
5、概念,构件是:已被封装的、具有良好接口定义的软件包可以被独立地开发和部署,可由第三方来组合能够与其它构件组合具有清晰的接口和文档,并定义了复用的情景注:构件不是对象,也不一定使用对象技术实现。从粒度上,构件一般都比对象类大,面向对象的构件一般实现为一组类的集合,11,构件的要素,规格说明:建立在接口概念之上,作为服务提供方与客户方之间的契约一个或多个实现受约束的构件标准包装方法部署方法,12,3C构件模型:一个指导性模型,构件由三个不同方面的描述组成概念(concept):关于“构件做什么”的抽象描述,可以通过概念去理解构件的功能。概念包括接口规约和语义描述(和每个操作相关联,一般表示为前后置
6、谓词形式)内容(content):概念的具体实现,描述构件如何完成概念所刻画的功能情境(context):描述构件和外围环境在概念级和内容级的关系,刻画构件的应用环境,为构件的选用和适应性修改提供指导,13,常用的构件标准,CORBA(Common Object Request Broker Architecture)OMG发布的构件标准核心是ORB(Object Request Broker),定义了异构环境下对象透明地发送请求和接收响应的基本机制COM+微软开发的一个构件对象模型,提供了在运行于Windows操作系统之上的单个应用中使用不同厂商生产的对象的规约 EJB:基于Java的构件提
7、供了让客户端使用远程的分布式对象的框架EJB规约规定了EJB构件如何与EJB容器进行行交互,14,构件化软件开发(CBSD),15,构件化软件开发的比较,Analysis,Component Acquisition,Component Oriented Design,Component Composition,Integration Test,System Test,构件化软件开发过程,Implementation,Unit Test,传统的软件过程,Analysis,Design,Integration Test,System Test,16,基于构件的软件开发过程,17,领域工程步骤,领域
8、分析建立领域特定的基准体系结构模型标识候选构件泛化(generalization)和可变性(variability)分析重建构件构件的测试构件的包装构件入库,18,应用系统工程的步骤,建立应用系统的体系结构模型寻找候选构件评价和选择合适的构件构件的修改(modify)和特化(specialize)开发未被复用的部分构件的组装集成测试评价被复用的构件,并推荐可能的新构件,19,基于构件的软件开发中的关键活动,(1)查找构件发掘待开发应用中的核心构件,用文档描述构件;通过领域分析、自行开发、逆向工程或者商业购买等途径来获得所需构件;创建构件库(2)选择构件从构件库中挑选合适的构件。选择过程通常与构
9、件库的检索技术及算法相关(3)适配构件改编或者定制化所挑选的构件来满足新的应用需求,使其能与其它构件或者底层框架集成,20,基于构件的软件开发中的关键活动(续),(4)创建构件所选择的构件不能完全满足应用需求,这时必须开发和创建新的构件(5)组合构件组装和集成构件的过程。工作量取决于构件的性质(6)替换构件替换构件的过程与产品的维护有关,构件升级及其版本管理,21,构件化开发中值得注意的问题,技术方面构件接口应该清晰、标准开发过程模型:以接口为中心;独立于编程语言;组合性;分离性集成能力 商业方面构件市场和标准 市场的范围、规模和标准化,22,Software Industry In the
10、Real World,Flashline(flashline)Javabeans/COM/ActiveXVbxtras(vbxtras)Visual BasicComponent Source(componentsource)Java/COM/C+/Delphi/VisualStudio,23,24,基于构件的开发活动(1):构件选择,在构件库中浏览和检索构件 检索的效率检索的精确性构件存储和分类的标准构件的存在形式:源代码,可执行代码使用范围:在单个项目中使用,整个产品线中使用,多个产品线使用查询表示方法:功能说明,关键字列表,设计模式,行为样例构件表示方法:功能说明,源代码,执行代码,关键
11、字检索目标:精确性,功能近似性,结构近似性匹配标准:正确性,关键字的相等性和包容性,自然语言分析,25,构件的管理,构件的分类描述对构件库中的构件进行合理的分类和组织,帮助软件开发人员方便地找到所需要的构件大多数的研究都建议使用图书馆科学索引方法进行构件分类构件库管理系统:主要用于构件的储存、检索、浏览和管理,26,常用的构件分类模式-1,枚举分类(Enumerated Classification)将构件组织成分类层次结构,构件库中的构件按某些性质分成若干大类,每个大类又分成若干较小的类,经过若干次分解,形成构件分类的层次结构,实际的构件位于层次结构的最低层,其它层次则表示构件的类或子类枚举
12、分类模式的分层结构易于理解和检索,但是,在建立层次结构之前,必须进行领域分析,寻找合适的供分类的性质。属性值分类(Attribute_Value Classification)为所有构件定义一组属性,每个构件都具有一组属性值,开发人员通过指定一组属性值对构件库检索,27,常用的构件分类模式-2,刻面分类(Faceted Classification)根据一组刻面对构件分类,每个刻面从不同的侧面对构件库中的构件进行分类,并根据重要性设置刻面的优先级每个刻面由一组术语(term)构成,称之为术语空间(term space),这些术语通常是描述性的关键词检索:用户通过指定一组刻面的术语值寻找匹配的构
13、件使用同义词词典(thesaurus)解决用户指定的术语值与库中构件所对应的术语值之间的不一致问题评价:具有较好的灵活性,易于加入新的刻面值,比枚举分类模式易于扩展和修改,28,构件库管理系统的主要功能,构件的分类存储(即添加构件):根据构件库的分类模型将入库的构件储存在构件库中构件检索:从构件库中检索出满足用户要求或接近用户要求的构件.构件库浏览:浏览库中的全部或部分构件删除构件:将不再使用的构件从构件库中删去构件使用情况评价:根据用户使用和检索构件的反馈意见对构件作出评价,为进一步的改进提供依据,29,构件的描述和检索,构件库管理系统的两个关键技术,直接影响到构件库检索的查准率(preci
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 组件 软件工程 课件

链接地址:https://www.31ppt.com/p-3953548.html