软件构架、架构、框架区别.docx

上传人:豆**** 文档编号:28547833 上传时间:2022-07-28 格式:DOCX 页数:7 大小:22.21KB
返回 下载 相关 举报
软件构架、架构、框架区别.docx_第1页
第1页 / 共7页
软件构架、架构、框架区别.docx_第2页
第2页 / 共7页
点击查看更多>>
资源描述

《软件构架、架构、框架区别.docx》由会员分享,可在线阅读,更多相关《软件构架、架构、框架区别.docx(7页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、精品文档,仅供学习与交流,如有侵权请联系网站删除软件框架(SoftwareFramework)介绍面向某领域(包括业务领域,如ERP,和计算领域,如GUI)的、可复用的“半成品”软件,它实现了该领域的共性部分,并提供一系列定义良好的可变点以保证灵活性和可扩展性。可以说,软件框架是领域分析结果的软件化,是领域内最终应用系统的模板。随着软件规模的扩大、应用的广泛和软件复用技术的发展,以子程序或类(Class)为单位的软件复用有许多不足:(1)子程序库日趋其庞大以致于使用人员难以掌握,(2)大多数类粒度很小,且其自身往往不能完成有用的功能。这一问题迫使人们在复用中将一组类(或模块)及其交互作为一个整

2、体来考虑,由此出现了软件框架。软件框架至少包含以下组成部分:(1)一系列完成计算的模块,在此称为构件。(2)构件之间的关系与交互机制。(3)一系列可变点(也称热点,Hot-spots,或调整点)。(4)可变点的行为调整机制。开发人员通过软件框架的行为调整机制,将领域中具体应用所特有的软件模块绑定到该软件框架的可变点,从而得到最终应用系统,这一过程称为软件框架的例化(instantiation)。通过软件框架的使用,开发人员可将主要精力放在应用所特有的模块的开发上,从而大大提高了软件生产率和质量。软件框架的行为调整机制是指如何针对具体的应用调整该框架的可变部分、如何在可变点加入特定应用模块所采用

3、的方法和规则。行为调整机制可分为四种:(1)模板参数化。软件框架提供代码自动生成工具,该工具根据用户设置的参数自动生成所需的代码。(2)继承和多态。通过面向对象中的子类继承和重载,在子类中加入新的功能或改变父类的行为。(3)动态绑定。在运行时刻动态绑定所需的对象服务,可通过软件模式技术实现。(4)构件替换。通过替换框架中可插拔的构件来加入业务特定的功能,不同于一般的可复用软件制品,软件框架的一个显著特点是逆向控制(InversionofControl),在复用过程中,前者需被显式调用,控制是在应用特定的模块中,软件框架则不然,应用开发人员只要将应用特定的模块绑定到框架内,框架则根据自己的交互机

4、制自动调用该模块,控制由框架负责。软件框架有很多种。按其应用的范围可分为:(1)系统基础设施框架。用于简化系统级软件的开发,如操作系统、用户界面、语言处理等,典型例子为MacApp,MicrosoftsMFC等。(2)中间件集成框架。用于组装分布式应用和构件,典型例子为MicrosoftsDCOM,JavaSoftsRMI,OMGsCORBA等(3)企业应用框架。用于各类应用领域,如电信、制造业、金融等。按其表现形态可分为:(1)白盒框架。支持白盒复用,大型的类库或子程序库通常均提供白盒框架来协助复用。(2)黑盒框架。支持黑盒复用。中间件集成框架一般为黑盒框架。构架和架构也就是通常所说的软件体

5、系结构(softwarearchitecture).体系结构一般包括三个部分:构件,用于描述计算;连接器,用于描述构件的连接部分;配置,将构件和连接器组成一个有机整体.对体系结构比较严谨比较认可的定义可参见软件工程技术概论(科学出版社)体系结构与框架(Framework)的区别与联系如下:.呈现形式不同体系结构的呈现形式是一个设计规约,而框架则是程序代码目的不同体系结构的首要目的大多是指导一个软件系统的实施与开发;而框架的首要目的是为复用因此,一个框架可有其体系结构,用于指导该框架的开发,反之不然有种特殊的体系结构,DSSA(领域特定体系结构)其首要目的也是为了复用4.有个叫体系结构风格的东西

6、,将它用程序代码实现后就成了Corba,COM之类的东西,它们俩叫体系结构框架,也叫中间件集成框架,又有人愿意叫它对象中间件什么是模式?什么是框架?(简述)UB(UB5023MSN.COM)2003-6-6现在软件设计里到处都是模式,框架。有次朋友问什么是模式?我也在学习中,就我的学习经验,给出以下小结。(注意:个人观点,仅供参考,欢迎指正。)1什么是模式?模式,即pattern。其实就是解决某一类问题的方法论。你把解决某类问题的方法总结归纳到理论高度,那就是模式。Alexander给出的经典定义是:每个模式都描述了一个在我们的环境中不断出现的问题,然后描述了该问题的解决方案的核心。通过这种方

7、式,你可以无数次地使用那些已有的解决方案,无需在重复相同的工作。模式有不同的领域,建筑领域有建筑模式,软件设计领域也有设计模式。当一个领域逐渐成熟的时候,自然会出现很多模式。什么是框架?框架,即framework。其实就是某种应用的半成品,就是一组组件,供你选用完成你自己的系统。简单说就是使用别人搭好的舞台,你来做表演。而且,框架一般是成熟的,不断升级的软件。2为什么要用模式?因为模式是一种指导,在一个良好的指导下,有助于你完成任务,有助于你作出一个优良的设计方案,达到事半功倍的效果。而且会得到解决问题的最佳办法。为什么要用框架?因为软件系统发展到今天已经很复杂了,特别是服务器端软件,设计到的

8、知识,内容,问题太多。在某些方面使用别人成熟的框架,就相当于让别人帮你完成一些基础工作,你只需要集中精力完成系统的业务逻辑设计。而且框架一般是成熟,稳健的,他可以处理系统很多细节问题,比如,事物处理,安全性,数据流控制等问题。还有框架一般都经过很多人使用,所以结构很好,所以扩展性也很好,而且它是不断升级的,你可以直接享受别人升级代码带来的好处。框架一般处在低层应用平台(如J2EE)和高层业务逻辑之间的中间层。软件为什么要分层?为了实现“高内聚、低耦合”。把问题划分开来各个解决,易于控制,易于延展,易于分配资源总之好处很多啦:)。3.以下所述主要是JAVA,J2EE方面的模式和框架:常见的设计模

9、式有什么?首先,你要了解的是GOF的设计模式-可复用面向对象软件的基础一书(这个可以说是程序员必备的了),注意:GOF不是一个人,而是指四个人。它的原意是GangsOfFour,就是“四人帮”,就是指此书的四个作者:ErichGamma,RichardHelm,RalphJohnson,JohnVlissides。这本书讲了23种主要的模式,包括:抽象工厂、适配器、外观模式等。还有其他的很多模式,估计有100多种。软件设计模式太多,就我的理解简单说一下最常见的MVC模式。MVC模式是1996年由Buschmann提出的:模型(Model):就是封装数据和所有基于对这些数据的操作。视图(View

10、):就是封装的是对数据显示,即用户界面。控制器(Control):就是封装外界作用于模型的操作和对数据流向的控制等。另外:RUP(RationalUnifiedProcess)软件统一过程,XP(ExtremeProgramming)极端编程,这些通常被叫做“过程方法”,是一种软件项目实施过程的方法论,它是针对软件项目的实施过程提出的方法策略。也是另一个角度的模式。4.常见的JAVA框架有什么? WAF:全称:WEBAPPLICATIONFRAMEWORK主要应用方面:EJB层,(WEB层也有,但是比较弱)。主要应用技术:EJB等出处:简述:这是SUN在展示J2EE平台时所用的例子PetSto

11、re(宠物商店系统)里面的框架。是SUN蓝皮书例子程序中提出的应用框架。它实现了MVC和其他良好的设计模式。SUN的网站上有技术资料,最好下载PetStore来研究,WEBLOGIC里自带此系统,源码在bea/weblogic700/samples/server/src/petstore。这是学习了解J2EE的首选框架。免费。Struts:主要应用方面:WEB层。主要应用技术:JSP,TagLib,JavaBean,XML等出处:http:/jakarta.apache.org/struts/index.html简述:这是APACHE的开源项目,目前应用很广泛。基于MVC模式,结构很好,基于J

12、SP。Jbuilder8里已经集成了STRUTS1.02的制作。免费。简述WAF+STRUTS结合的例子:WEB层用STRUTS,EJB层用WAF:JSP(TagLib)ActionFormActionEventEJBActionEJBDAODatabaseJSP(TagLib)(forward)ActionEventResponseTurbine:主要应用方面:WEB层。主要应用技术:servlet等出处:http:/jakarta.apache.org/turbine/index.html简述:这是APACHE的开源项目。基于SERVLET。据说速度比较快,基于service(plugga

13、bleimplementation可插拔的执行组件)的方式提供各种服务。免费。COCOON:主要应用方面:WEB层。主要应用技术:XML,XSP,servlet等出处:http:/cocoon.apache.org/2.0/简述:这是APACHE的一个开源项目。基于XML,基于XSP(通俗地说,XSP是在XML静态文档中加入Java程序段后形成的动态XML文档。)。特点是可以与多种数据源交互,包括文件系统,数据库,LDAP,XML资源库,网络数据源等。免费。ECHO:主要应用方面:WEB层。主要应用技术:servlet等出处:简述:nextapp公司的一个开源项目。基于SERVLET。页面可以

14、做的很漂亮,结合echopoint,可以作出很多图形效果(里面用了jfreechart包)。使用SWING的思想来作网页,把HTML当作JAVA的类来做。但是大量使用Session,页面分帧(Frame)很多,系统资源消耗很大。免费。JATO:全称:SUNONEApplicationFramework主要应用方面:WEB层。主要应用技术:JSP,TagLib,JavaBean等出处:简述:这是SUN推出的一个商业性框架,一看名字就知道是结合SUNONE的平台推出的。我下载了JATO2.0看了一下,感觉有些简单,使用了JSPTagLib+JavaBean。如他的DOC所说JATO是适合用在小的W

15、EB应用里。免费。TCF:全称:Thin-ClientFramework主要应用方面:JAVAGUI。主要应用技术:JAVAapplication等出处:简述:这是IBM出的一个框架。基于MVC模式,基于JAVAApplication。推荐一篇介绍文章:收费:每个企业对象license:2000美元。5.其实本文的目的在于“抛砖引玉”,希望各路高手请你们把各种框架的特点和出处罗列一下,供大家参考,选用。构架、框架、设计模式之间的关系简述一、软件体系结构和框架的定义 软件体系结构的英文单词是“architecture”. Architecture的基本词义是建筑、建筑学、建筑风格。 软件体系结构

16、虽然根植于软件工程,但还处于一个研究发展的阶段,迄今为止还没有一个为大家所公认的定义。 设计模式中对框架的定义是框架就是一组相互协作的类,对于特定的一类软件,框架构成了一种可重用的设计。 软件框架是项目软件开发过程中提取特定领域软件的共性部分形成的体系结构,不同领域的软件项目有着不同的框架类型。框架的作用在于:由于提取了特定领域软件的共性部分,因此在此领域内新项目的开发过程中代码不需要从头编写,只需要在框架的基础上进行一些开发和调整便可满足要求;对于开发过程而言,这样做会提高软件的质量,降低成本,缩短开发时间,使开发越做越轻松,效益越做越好,形成一种良性循环。 框架不是现成可用的应用系统。是一

17、个半成品,需要后来的开发人员进行二次开发,实现具体功能的应用系统。框架不是“平台”,平台概念比较模糊可以是一种操作系统,一种应用服务器,一种数据库软件,一种通讯中间件等地那个,因此平台在应用平台主要指提供特定服务的系统软件,而框架更侧重了设计,开发过程,或者可以说,框架通过调用平台提供的服务而起的作用。 框架不是工具包或者类库,调用API并不就是在使用框架开发,紧紧使用API是,开发者完成系统的主题部分,并不时地调用类库实现特定任务。而框架构成了通用的、具有一般性的系统主体部分,二次开发人员只是像做填空一样,根据具体业务,完成特定应用系统中与众不同的特殊部分。二、框架与架构之间的关系 框架不是

18、构架(即软件体系机构)。体系结构确定了系统整体结构、层次划分,不同部分之间的协作等设计考虑。框架比架构更具体。更偏重于技术涉嫌。确定框架后,软件体系结构也随之确定,而对于同一软件体系结构(比如Web开发中的MVC),可以通过多种框架来实现。三、框架与设计模式之间的关系 设计模式和框架在软件设计中是两个不同的研究领域。设计模式研究的是一个设计问题的解决方法,一个模式可应用于不同的框架和被不同的语言所实现;而框架则是一个应用的体系结构,是一种或多种设计模式和代码的混合体虽然它们有所不同,但却共同致力于使人们的设计可以被重用,在思想上存在着统一性的特点,因而设计模式的思想可以在框架设计中进行应用。

19、框架和设计模式存在着显著的区别,主要表现在二者提供的内容和致力应用的领域。 1)、从应用领域上分,框架给出的是整个应用的体系结构;而设计模式则给出了单一设计问题的解决方案,并且这个方案可在不同的应用程序或者框架中进行应用。 2)、从内容上分,设计模式仅是一个单纯的设计,这个设计可被不同语言以不用方式来实现;而框架则是设计和代码的一个混合体,编程者可以用各种方式对框架进行扩展,进而形成完整的不同的应用。 3)、以第二条为基础,可以得出设计模式比框架更容易移植:框架一旦设计成形,虽然还没有构成完整的一个应用,但是以其为基础进行应用的开发显然要受制于框架的实现环境;而设计模式是与语言无关的,所以可以在更广泛的异构环境中进行应用。 总之,框架是软件,而设计模式是软件的知识体,提升框架的设计水平。【精品文档】第 7 页

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 小学资料

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁