基于构件的软件开发包括哪些要素,其核心是什么(软件开发中模块设计的原则是)
与传统的软件开发方式相比,基于构件的软件开发方法有什么突破呢?一、体系结构软件体系结构代表了系统公共的高层次的抽象,它是系统设计成败的关键
其设计的核心是能否使用重复的体系模式
传统的应用系统体系结构从基于主机的集中式框架,到在网络的客户端上通过网络访问服务器的框架,都不能适应目前企业所处的商业环境,原因是:企业过分地依赖于某个供应商的软件和硬件产品
这种单一供应商使得企业难以利用计算供应商的免费市场,将计算基础设施的重要决定交给第三方处理,这显然不利于企业在合作伙伴之间共享信息
不能适应远程访问的分布式、多层次异构系统
封装的应用系统在出现某种组织需要时,难以用定制来维护系统,从而难以满足多变的需求
不能实现分析、设计核心功能重用,最多只能实现代码重用
如今,应用系统已经发展成为在Intranet和Internet上的各种客户端可远程访问的分布式、多层次异构系统
CBSD为开发这样的应用系统提供了新的系统体系结构
它是标准定义的、分布式、模块化结构,使应用系统可分成几个独立部分开发,可用增量方式开发
这样的体系结构实现了CBSD的以下几点目标:能够通过内部开发的、第三方提供的或市场上购买的现有构件,来集成和定制应用软件系统
鼓励在各种应用系统中重用核心功能,努力实现分析、设计的重用
系统都应具有灵活方便的升级和系统模块的更新维护能力
封装最好的实践案例,并使其在商业条件改变的情况下,还能够被采用,并能保留已有资源
由此看出,CDSD从系统高层次的抽象上解决了复用性与异构互操作性,这正是分布式网络系统所希望解决的难题
二、开发过程传统的软件开发过程在重用元素、开发方法上都与CBSD有很大的不同
虽然面向对象技术促进了软件重用,但是,只实现了类和类继承的重用
在整个系统和类之间还存在很大的缺口
为填补这个缺口,人们曾想了许多方法,如系统体系结构、框架、设计模式等
自从构件出现以来,软件的重用才得到了根本改变
CBSD实现了分析、设计、类等多层次上的重用
图1显示了它的重用元素分层实现
在分析抽象层上,重用元素有子系统、类;在设计层上重用元素有系统体系结构、子系统体系结构、设计模式、框架、容器、构件、类库、模板、抽象类等
在软件开发方法上,CBSD引导软件开发从应用系统开发转变为应用系统集成
建立一个应用系统需要重用很多已有的构件模块,这些构件模块可能是在不同的时间、由不同的人员开发的,并有各种不同的用途
在这种情况下,应用系统的开发过程就变成对构件接口、构件上下文以及框架环境一致性的逐渐探索过程
例如,在J2EE平台上,用EJB框架开发应用系统,主要工作是将应用逻辑,按sessionBean、entityBean设计开发,并利用JTS事务处理的服务实现应用系统
其主要难点是事务划分、构件的部署与开发环境配置
概括地说,传统的软件开发过程是串行瀑布式、流水线的过程;而CBSD是并发进化式,不断升级完善的过程
图2显示了它们的不同
三、软件方法学软件方法学是从各种不同角度、不同思路去认识软件的本质
传统的软件方法学是从面向机器、面向数据、面向过程、面向功能、面向数据流、面向对象等不断创新的观点反映问题的本质
整个软件的发展历程使人们越来越认识到应按客观世界规律去解决软件方法学问题
直到面向对象方法的出现,才使软件方法学迈进了一大步
但是,高层次上的重用、分布式异构互操作的难点还没有解决
CBSD发展到今天,才在软件方法学上为解决这个难题提供了机会
它把应用业务和实现分离,即逻辑与数据的分离,提供标准接口和框架,使软件开发方法变成构件的组合
因此,软件方法学是以接口为中心,面向行为的设计
图3是其开发过程
归纳起来,CBSD的软件开发方法学应包括下面几方面:对构件有明确的定义
基于构件的概念需要有构件的描述技术和规范,如UML、JavaBean、EJB、Servlet规范等
开发应用系统必须按构件裁剪划分组织,包括分配不同的角色
有支持检验构件特性和生成文档的工具,确保构件规范的实现和质量测试
总之,传统的软件方法学从草稿自顶向下进行,对重用没有提供更多的辅助
CBSD的软件方法学要丰富得多,它是即插即用,基于体系结构,以接口为中心,将构件有机组合,它把自顶向下和自底向上方法结合起来进行开发
四、开发组织机构传统软件的开发组织一般由分析员、设计员、程序员和测试员组成
对一个小的应用系统来说,一个熟练的开发人员,可能兼顾以上多个角色
但对CBSD来说,因为构件开发与应用系统集成往往是分开进行的,因此整个开发过程由六个角色来完成,他们是:构件开发者也是构件供货商,这些大多数是中间件构件提供(续致信网上一页内容)者
应用构件集成者针对某应用领域将已有构件组合成更大的构件模块或容器,作为系统部署的基本单元
应用系统部署者将系统部署基本单元放入选定的平台环境或基本框架中,完成软件定制的要求
开发平台服务器供应商提供服务器、操作系统和数据库等基本软件
应用系统开发工具供应商提供构件公共设施服务
系统管理员配置硬件、网络和操作系统,监督和维护应用系统者
这六个角色的工作专业性很强,要兼顾成为多面手很不容易
目前已形成构件开放市场,而且还很火红
这也是当今软件人才大战所遇的一个困惑
因此,在CBSD中,如何组织好开发队伍尤为重要,必须按本企业所具备人才来组织
特别重要的是:开发初期必须选好标准框架,以及统一的开发指导方针,保证在整个开发过程中,各角色能随时互相沟通
一般来说,CBSD的人员素质决定了构件的重用率
五、构造方法传统应用软件的构造是用白盒子方法,应用系统的实现全在代码中,应用逻辑和数据粘结在一起
而CBSD的构造是用白盒子和黑盒子相结合的方法
基于构件的框架是用两个概念来支持演变:第一个概念是构件有很强的性能接口,使构件逻辑功能和构件模型的实现都隐藏起来
这样,只要接口相同,构件就可以被替换
第二个概念是隐式调用,即在基于构件的框架中,从来不直接给构件的接口分配地址,只在识别构件用户后才分配地址
因此,构件用户只要了解接口要求和为构件接口提供的引用后的返回信息(该引用可能是一个构件,也可能是一个构件代理
对构件用户来说,构件代理就是构件,不用区分)
构件接口的信息并不存入构件内,而是存入构件仓库或注册处
这样才能保证构件替换灵活,并很容易利用隐式调用去重新部署构件
由于构件的实现对用户透明,因此也使构件能适应各种不同的个性化要求
为此,构件提供自检和规范化两个机制
自检保证在不了解构件的具体实现时,就能获得构件接口信息
例如,JavaBean提供的自检机制是Reflection和BeanInfo,通过Reflection可直接获得Bean构件的全部方法,通过BeanInfo可直接获得构件的许多复杂信息
规范化允许不访问构件就可以修改它,如JavaBean提供的规范化是propertysheet和customizer(定制器)
通过propertysheet提供一组简单参数,修改Bean的属性
复杂的修改由用户通过定制器设置参数完成
基于构件的软件开发的优势是什么
基于构件的软件开发的优势是什么如下:基于构件的软件开发是一种软件开发方法,它将软件系统分解为多个独立的、可重用的构件,并将它们组合成一个完整的软件系统。基于构件的软件开发具有以下优势:1.提高软件开发效率:基于构件的软件开发可以将软件系统分解为多个独立的构件,每个构件都可以重复使用,这样可以...
构件软件工程中的构件
例如,Ada的Package、Smalltalk-80的类和C++的类和数据类型都被视为构件。然而,仅仅复用操作集合、过程或函数并不满足构成一个构件的条件。开发者通过组合现有的构件来创建新应用,从而实现软件复用的核心价值。软件构件的关键特性包括:有用性,提供有效功能;可用性,易于理解和使用;质量,确保正确运行和...
21世纪高等学校规划教材:软件工程内容简介
高级篇是软件工程的高级研究领域,包括软件工程管理、过程管理、基于构件的软件工程(CBSE)、客户\/服务器(C\/S)软件工程以及柔性软件开发技术。这部分内容针对的是对软件工程有深入研究需求的专业人士,提供了更高级的理论和实践指导。《21世纪高等学校规划教材:软件工程》适用于高等教育机构的软件工程和...
什么是构件:
4. Gartner Group定义:运行时软件构件是一个可动态绑定的、含一个或多个程序的软件包,它作为一个独立单位,通过运行时可辨别的文档化接口加以管理和存取。5. Bertrand Meyer定义了构件的七个条件,包括可被其它软件成分使用、客户的使用不干扰构件的开发者、包括依赖的全部说明、提供功能的精确说明、...
软件工程名词解释(二)
实例: 是由某个特定的类所描述的一个具体的对象。消息: 是要求某个对象执行在定义它的那个类中所定义的某个操作的规格说明。多态性: 是指同一个操作作用于不同的对象上可以有不同的解释,并产生不同的执行结果。基于构件的软件开发(CBSD): 是指使用可复用构件来开发应用软件。查全率=预测为1...
软件开发的定义是什么呢?
软件开发的定义:软件开发(Software development)是根据用户要求建造出软件系统或者系统中的软件部分的过程。它是一项包括需求获取、开发规划、需求分析和设计、编程实现、软件测试、版本控制的系统工程。 软件开发包括研究、修改、复用、重新设计(再工程)、维护等活动,通常采用软件开发工具进行开发。对所要...
软件过程模型基于构件的开发过程模型
在软件工程领域,面向对象的技术为基于构件的开发过程模型构建了坚实的基础。这种模型强调通过创建类、封装数据和相关操作算法,实现类的复用,使其能在不同的应用和系统架构中灵活应用。基于构件的开发模型深受螺旋模型的影响,本质上采用迭代方法进行软件构建,允许在开发过程中进行逐步改进。开发流程通常始于...
软件开发过程中的需求分析与开发框架的区别
1) 优点: 结构化分析方法是软件需求分析中公认的、有成效的、技术成熟的、使用广泛的一种方法,它较适合于开发数据处理类型软件的需求分析,该方法利用图形等半形式化工具表达需求,简明易读,也易于使用,为后一阶段的设计、测试、评价提供了有利条件。 2) 缺点:① 传统的SA方法主要用于数据处理方面的问题,主要工具DFD...
软件构件流派有哪些
微服务架构流派 微服务架构流派强调将软件系统划分为一系列小型的、独立的服务,每个服务运行在其自己的进程中,并使用轻量级通信机制进行通信。微服务架构有助于提高系统的可扩展性、可维护性和灵活性。这种流派适用于构建大型、复杂的软件系统,如云计算平台、电商平台等。软件构件流派是软件开发中不同的设计...
基于构件的开发模型优缺点?
4.演化过程模型:包括原型开发模型、螺旋模型、协同开发模型 5.专用过程模型:包括基于构件的开发模型、形式化方法模型、面向方面的软件开发 1.瀑布模型 它提出了软件开发的系统化的、顺序的方法。其流程从系统开始,随后是需求分析、设计、编码、测试、支持。这种模型是最早也是应用最广泛的软件过程模型(虽然这种模型会引...