软件构架、架构和框架的区别

上传人:kms****20 文档编号:37252171 上传时间:2018-04-09 格式:DOC 页数:5 大小:39.50KB
返回 下载 相关 举报
软件构架、架构和框架的区别_第1页
第1页 / 共5页
软件构架、架构和框架的区别_第2页
第2页 / 共5页
软件构架、架构和框架的区别_第3页
第3页 / 共5页
软件构架、架构和框架的区别_第4页
第4页 / 共5页
软件构架、架构和框架的区别_第5页
第5页 / 共5页
亲,该文档总共5页,全部预览完了,如果喜欢就下载吧!
资源描述

《软件构架、架构和框架的区别》由会员分享,可在线阅读,更多相关《软件构架、架构和框架的区别(5页珍藏版)》请在金锄头文库上搜索。

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

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

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

4、特定的模块中,软件框架则不 然,应用开发人员只要将应用特定的模块绑定到框架内,框架则根据自己的交互机制自动 调用该模块,控制由框架负责。 软件框架有很多种。按其应用的范围可分为: (1) 系统基础设施框架。用于简化系统级软件的开发,如操作系统、用户界面、语言处 理等,典型例子为 MacApp, Microsofts MFC 等。 (2) 中间件集成框架。用于组装分布式应用和构件,典型例子为 Microsofts DCOM, JavaSofts RMI, OMGs CORBA 等 (3) 企业应用框架。用于各类应用领域,如电信、制造业、金融等。 按其表现形态可分为: (1) 白盒框架。支持白盒复

5、用,大型的类库或子程序库通常均提供白盒框架来协助复用。(2) 黑盒框架。支持黑盒复用。中间件集成框架一般为黑盒框架。构架和架构也就是通常所说的软件体系结构(software architecture).体系结构一般包括三个部分:构件,用于描述计算;连接器,用于描述构件的连接部分;配置,将构件和连接器组成一个有 机整体.对体系结构比较严谨比较认可的定义可参见软件工程技术概论(科学出版社) 体系结构与框架(Framework)的区别与联系如下: .呈现形式不同体系结构的呈现形式是一个设计规约,而框架则是程序代码 目的不同体系结构的首要目的大多是指导一个软件系统的实施与开发;而框架的首 要目的是为复

6、用因此,一个框架可有其体系结构,用于指导该框架的开发,反之不然 有种特殊的体系结构,DSSA(领域特定体系结构)其首要目的也是为了复用 4.有个叫体系结构风格的东西,将它用程序代码实现后就成了 Corba,COM 之类的东西,它 们俩叫体系结构框架,也叫中间件集成框架,又有人愿意叫它对象中间件什么是模式?什么是框架?(简述)UB (UB5023MSN.COM) 2003-6-6现在软件设计里到处都是模式,框架。有次朋友问什么是模式?我也在学习中,就我的 学习经验,给出以下小结。 (注意:个人观点,仅供参考,欢迎指正。 ) 1什么是模式? 模式,即 pattern。其实就是解决某一类问题的方法论

7、。你把解决某类问题的方法总结归纳 到理论高度,那就是模式。 Alexander 给出的经典定义是:每个模式都描述了一个在我们的环境中不断出现的问题,然 后描述了该问题的解决方案的核心。通过这种方式,你可以无数次地使用那些已有的解决 方案,无需在重复相同的工作。 模式有不同的领域,建筑领域有建筑模式,软件设计领域也有设计模式。当一个领域逐渐 成熟的时候,自然会出现很多模式。什么是框架? 框架,即 framework。其实就是某种应用的半成品,就是一组组件,供你选用完成你自己 的系统。简单说就是使用别人搭好的舞台,你来做表演。而且,框架一般是成熟的,不断 升级的软件。2为什么要用模式? 因为模式是

8、一种指导,在一个良好的指导下,有助于你完成任务,有助于你作出一个优良 的设计方案,达到事半功倍的效果。而且会得到解决问题的最佳办法。为什么要用框架? 因为软件系统发展到今天已经很复杂了,特别是服务器端软件,设计到的知识,内容,问 题太多。在某些方面使用别人成熟的框架,就相当于让别人帮你完成一些基础工作,你只 需要集中精力完成系统的业务逻辑设计。而且框架一般是成熟,稳健的,他可以处理系统 很多细节问题,比如,事物处理,安全性,数据流控制等问题。还有框架一般都经过很多 人使用,所以结构很好,所以扩展性也很好,而且它是不断升级的,你可以直接享受别人 升级代码带来的好处。 框架一般处在低层应用平台(如

9、 J2EE)和高层业务逻辑之间的中间层。软件为什么要分层?为了实现“高内聚、低耦合” 。把问题划分开来各个解决,易于控制,易于延展,易于 分配资源总之好处很多啦:) 。3. 以下所述主要是 JAVA,J2EE 方面的模式和框架:常见的设计模式有什么?首先,你要了解的是 GOF 的设计模式-可复用面向对象软件的基础一书(这个可以 说是程序员必备的了) ,注意:GOF 不是一个人,而是指四个人。它的原意是 Gangs Of Four,就 是“四人帮” ,就是指此书的四个作者:Erich Gamma,Richard Helm,Ralph Johnson,John Vlissides。这本书讲了 23

10、 种主要的模式,包括:抽象工厂、适配器、外观模式等。 还有其他的很多模式,估计有 100 多种。 软件设计模式太多,就我的理解简单说一下最常见的 MVC 模式。 MVC 模式是 1996 年由 Buschmann 提出的:模型(Model):就是封装数据和所有基于对这些数据的操作。视图(View):就是封装的是对数据显示,即用户界面。控制器(Control):就是封装外界作用于模型的操作和对数据流向的控制等。另外: RUP(Rational Unified Process)软件统一过程,XP(Extreme Programming)极端编程,这 些通常被叫做“过程方法” ,是一种软件项目实施过

11、程的方法论,它是针对软件项目的实施 过程提出的方法策略。也是另一个角度的模式。4. 常见的 JAVA 框架有什么? WAF: 全称:WEB APPLICATION FRAMEWORK 主要应用方面:EJB 层, (WEB 层也有,但是比较弱) 。 主要应用技术:EJB 等 出处:http:/ 简述:这是 SUN 在展示 J2EE 平台时所用的例子 PetStore(宠物商店系统)里面的框架。是 SUN 蓝皮书例子程序中提出的应用框架。它实现了 MVC 和其他良好的设计模式。SUN 的 网站上有技术资料,最好下载 PetStore 来研究,WEBLOGIC 里自带此系统,源码在 beaweblo

12、gic700samplesserversrcpetstore。这是学习了解 J2EE 的首选框架。 免费。Struts:主要应用方面:WEB 层。 主要应用技术:JSP,TagLib,JavaBean,XML 等 出处:http:/jakarta.apache.org/struts/index.html 简述:这是 APACHE 的开源项目,目前应用很广泛。基于 MVC 模式,结构很好,基于 JSP。Jbuilder8 里已经集成了 STRUTS1.02 的制作。 免费。简述 WAF+STRUTS 结合的例子:WEB 层用 STRUTS,EJB 层用 WAF: JSP(TagLib)Actio

13、nFormAction EventEJBActionEJB DAODatabase JSP(TagLib) (forward) Action EventResponse Turbine: 主要应用方面:WEB 层。 主要应用技术:servlet 等 出处:http:/jakarta.apache.org/turbine/index.html 简述:这是 APACHE 的开源项目。基于 SERVLET。据说速度比较快,基于 service(pluggable implementation 可插拔的执行组件)的方式提供各种服务。 免费。COCOON: 主要应用方面:WEB 层。 主要应用技术:XM

14、L,XSP,servlet 等 出处:http:/cocoon.apache.org/2.0/ 简述:这是 APACHE 的一个开源项目。基于 XML,基于 XSP(通俗地说,XSP 是在 XML 静 态文档中加入 Java 程序段后形成的动态 XML 文档。 ) 。特点是可以与多种数据源交互,包括 文件系统,数据库,LDAP,XML 资源库,网络数据源等。 免费。ECHO: 主要应用方面:WEB 层。 主要应用技术:servlet 等 出处:http:/ 简述:nextapp 公司的一个开源项目。基于 SERVLET。页面可以做的很漂亮,结合 echopoint,可以作出很多图形效果(里面用

15、了 jfreechart 包) 。使用 SWING 的思想来作网页, 把 HTML 当作 JAVA 的类来做。但是大量使用 Session,页面分帧(Frame)很多,系统资源消 耗很大。 免费。JATO: 全称:SUN ONE Application Framework 主要应用方面:WEB 层。 主要应用技术:JSP,TagLib,JavaBean 等 出处:http:/ 简述:这是 SUN 推出的一个商业性框架,一看名字就知道是结合 SUN ONE 的平台推出的。 我下载了 JATO2.0 看了一下,感觉有些简单,使用了 JSPTagLib+JavaBean。如他的 DOC 所说 JATO 是适合用在小的 WEB 应用里。 免费。TCF: 全称:Thin-Client Framework 主要应用方面:JAVA GUI。 主要应用技术:JAVA application 等出处:http:/ 简述:这是 IBM 出的一个框架。基于 MVC 模式,基于 JAVA Application。推荐一篇介绍文 章:http:/ 收费:每个企业对象 license:2000 美元。 5.其实本文的目的在于“抛砖引玉”

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

当前位置:首页 > 生活休闲 > 科普知识

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号