[讨论]什么是平台,什么是框架?二者区别何在?
当前平台、框架的概念十分流行。很多公司都有自己的平台或者开发框架,搞得我是都不知道什么是平台什么是框架了.
大家讨论一下,自己的看法。
问题点数:50、回复次数:29Top
1 楼J2SE_J2EE_J2ME(Write Once,Debug Anywhere)回复于 2005-07-20 21:45:28 得分 0
对开发者来说平台侧重描述系统的运行环境,框架侧重描述开发过程
不知道理解是不是存在问题
关注Top
2 楼jxdn_yang((我不想做IT了))回复于 2005-07-21 09:10:24 得分 0
平台就是WINDOES,LINUX,框架就是SPRING,STRUTS......嘻嘻Top
3 楼shoulders(Developer)回复于 2005-07-21 09:12:03 得分 0
平台就是你的身体,架构就是你的衣服,没有衣服,你就暴露了。Top
4 楼ses127127(ses)回复于 2005-07-21 09:36:39 得分 0
平台是程序运行所依赖的环境,而框架是建立在平台的基础之上一种通用的开发模式Top
5 楼echo123321(今年过年不回家)回复于 2005-07-21 11:50:12 得分 0
同意楼上。Top
6 楼lyguo(愚人(每天顶几顶挣分升星星)http://zz.ihenan.cn/map/)回复于 2005-07-21 18:39:33 得分 0
学习Top
7 楼freedemon(自由魔鬼)回复于 2005-08-21 00:51:07 得分 0
哦,有点明白了。继续Top
8 楼BugYou004()回复于 2005-08-21 01:19:05 得分 0
“平台是程序运行所依赖的环境,而框架是建立在平台的基础之上一种通用的开发模式”
学习中!!
Top
9 楼shenpipi(皮皮)回复于 2005-08-21 08:06:56 得分 0
哎,平台这个词用的太多了!Top
10 楼swanmarx(swan)回复于 2005-08-21 10:13:42 得分 0
平台是程序运行所依赖的环境,而框架是建立在平台的基础之上一种架构模式,架构模式是多种开发模式的组合.
Top
11 楼lonelydavy(davy)回复于 2005-08-21 21:35:50 得分 0
现在软件设计里到处都是模式,框架。有次朋友问什么是模式?我也在学习中,就我的学习经验,给出以下小结。(注意:个人观点,仅供参考,欢迎指正。)
1.什么是模式?
模式,即pattern。其实就是解决某一类问题的方法论。你把解决某类问题的方法总结归纳到理论高度,那就是模式。
Alexander给出的经典定义是:每个模式都描述了一个在我们的环境中不断出现的问题,然后描述了该问题的解决方案的核心。通过这种方式,你可以无数次地使用那些已有的解决方案,无需在重复相同的工作。
模式有不同的领域,建筑领域有建筑模式,软件设计领域也有设计模式。当一个领域逐渐成熟的时候,自然会出现很多模式。
什么是框架?
框架,即framework。其实就是某种应用的半成品,就是一组组件,供你选用完成你自己的系统。简单说就是使用别人搭好的舞台,你来做表演。而且,框架一般是成熟的,不断升级的软件。
2.为什么要用模式?
因为模式是一种指导,在一个良好的指导下,有助于你完成任务,有助于你作出一个优良的设计方案,达到事半功倍的效果。而且会得到解决问题的最佳办法。
为什么要用框架?
因为软件系统发展到今天已经很复杂了,特别是服务器端软件,设计到的知识,内容,问题太多。在某些方面使用别人成熟的框架,就相当于让别人帮你完成一些基础工作,你只需要集中精力完成系统的业务逻辑设计。而且框架一般是成熟,稳健的,他可以处理系统很多细节问题,比如,事物处理,安全性,数据流控制等问题。还有框架一般都经过很多人使用,所以结构很好,所以扩展性也很好,而且它是不断升级的,你可以直接享受别人升级代码带来的好处。
框架一般处在低层应用平台(如J2EE)和高层业务逻辑之间的中间层。
软件为什么要分层?
为了实现“高内聚、低耦合”。把问题划分开来各个解决,易于控制,易于延展,易于分配资源…总之好处很多啦:)。
3. 以下所述主要是JAVA,J2EE方面的模式和框架:
常见的设计模式有什么?
首先,你要了解的是GOF的《设计模式--可复用面向对象软件的基础》一书(这个可以说是程序员必备的了),注意:GOF不是一个人,而是指四个人。它的原意是Gangs Of Four,就是“四人帮”,就是指此书的四个作者:Erich Gamma,Richard Helm,Ralph Johnson,John Vlissides。这本书讲了23种主要的模式,包括:抽象工厂、适配器、外观模式等。
还有其他的很多模式,估计有100多种。
软件设计模式太多,就我的理解简单说一下最常见的MVC模式。
MVC模式是1996年由Buschmann提出的:
模型(Model):就是封装数据和所有基于对这些数据的操作。
视图(View):就是封装的是对数据显示,即用户界面。
控制器(Control):就是封装外界作用于模型的操作和对数据流向的控制等。
另外:
RUP(Rational Unified Process)软件统一过程,XP(Extreme Programming)极端编程,这些通常被叫做“过程方法”,是一种软件项目实施过程的方法论,它是针对软件项目的实施过程提出的方法策略。也是另一个角度的模式。
4. 常见的JAVA框架有什么?
WAF:
全称:WEB APPLICATION FRAMEWORK
主要应用方面:EJB层,(WEB层也有,但是比较弱)。
主要应用技术:EJB等
出处:http://java.sun.com/blueprints/code/index.html
简述:这是SUN在展示J2EE平台时所用的例子PetStore(宠物商店系统)里面的框架。是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模式,结构很好,基于JSP。Jbuilder8里已经集成了STRUTS1.02的制作。
免费。
简述WAF+STRUTS结合的例子:WEB层用STRUTS,EJB层用WAF:
JSP(TagLib)――>ActionForm――>Action ――>
Event――>EJBAction――>EJB ――>DAO――>Database
JSP(TagLib) (forward) <――Action <――EventResponse<――
Turbine:
主要应用方面:WEB层。
主要应用技术:servlet等
出处:http://jakarta.apache.org/turbine/index.html
简述:这是APACHE的开源项目。基于SERVLET。据说速度比较快,基于service(pluggable implementation可插拔的执行组件)的方式提供各种服务。
免费。
COCOON:
主要应用方面:WEB层。
主要应用技术:XML,XSP,servlet等
出处:http://cocoon.apache.org/2.0/
简述:这是APACHE的一个开源项目。基于XML,基于XSP(通俗地说,XSP是在XML静态文档中加入Java程序段后形成的动态XML文档。)。特点是可以与多种数据源交互,包括文件系统,数据库,LDAP,XML资源库,网络数据源等。
免费。
ECHO:
主要应用方面:WEB层。
主要应用技术:servlet等
出处:http://www.nextapp.com/products/echo/
简述:nextapp公司的一个开源项目。基于SERVLET。页面可以做的很漂亮,结合echopoint,可以作出很多图形效果(里面用了 jfreechart包)。使用SWING的思想来作网页,把HTML当作JAVA的类来做。但是大量使用Session,页面分帧(Frame)很多, 系统资源消耗很大。
免费。
JATO:
全称:SUN ONE Application Framework
主要应用方面:WEB层。
主要应用技术:JSP,TagLib,JavaBean等
出处:http://www.sun.com
简述:这是SUN推出的一个商业性框架,一看名字就知道是结合SUN ONE的平台推出的。我下载了JATO2.0看了一下,感觉有些简单,使用了JSP+TagLib+JavaBean。如他的DOC所说JATO是适合用在小的WEB应用里。
免费。
TCF:
全称:Thin-Client Framework
主要应用方面:JAVA GUI。
主要应用技术:JAVA application等
出处:http://www.alphaworks.ibm.com/tech/tcf
简述:这是IBM出的一个框架。基于MVC模式,基于JAVA Application。推荐一篇介绍文章:http://www-900.ibm.com/developerWorks/cn/java/j-tcf1/index.shtml
收费:每个企业对象license:2000美元。
5.其实本文的目的在于“抛砖引玉”,希望各路高手请你们把各种框架的特点和出处罗列一下 ,供大家参考,选用。
Top
12 楼mxlmwl(飞星)回复于 2005-08-23 11:21:05 得分 0
我的感觉是:
平台就是你的身体,或者是运行环境这种东西,它是最基本的,没有它,什么都是空的。
框架就是骨头,一个架子嘛,或者说算是一个近似模型的东西,有了这个东西,你在上面添枝加页,很快就可以做出东西来。
所以,应该是平台->框架->你的程序,就是这么个关系,明白了么?
这两个概念没什么可比性。而架构和框架才是比较容易弄混淆的,呵呵。Top
13 楼java620(头文字D)回复于 2005-09-01 16:28:40 得分 0
markTop
14 楼lomes(简单)回复于 2005-09-06 14:56:47 得分 0
top
Top
15 楼chengys()回复于 2005-09-12 17:41:45 得分 0
都说的很明白了。
平台是程序运行所依赖的环境。比如windows就是平台,它提供各种程序运行所以来的环境,不管是超级解霸还是msn还是ie都可以在windows上运行。当然windows是个大平台,很基础的。所以又叫操作系统。其他的开发平台如eclipse,它可以提供各种各样的开发语言的环境,当然需要插件。
框架,字面来看,很好理解,就是个架子。如果开发程序时采用了框架,那么你只能在所采用的框架范围内进行作业。采用框架的目的就是提高开发速度,提高开发质量,大部分共同的处理由框架来统一处理,程序开发者只要关注业务逻辑即可。所以从这个意义来说,采用了框架,你的程序实际上已经是个半成品,你索要作的只是把业务做好就可以了。
实际上,就像 mxlmwl(飞星(抓紧升星)) 说的,平台和框架这两个概念没什么可比性,根本不是一回事。
Top
16 楼a_thens(睡兰)回复于 2005-09-13 11:38:22 得分 0
up~Top
17 楼saiche05(赛车)回复于 2005-09-13 12:22:36 得分 0
平台是程序运行所依赖的环境,而框架是建立在平台的基础之上一种架构模式,架构模式是多种开发模式的组合.
Top
18 楼hawaii_wx(梦见夏威夷)回复于 2005-09-17 09:23:21 得分 0
平台的范围很大,是一种编程语言所必须的建立的环境,每种语言都有自己的特色,框架只是依赖在平台上运行的一些封装好的组件,框架的好处是大家如果用同一种框架,那么都是遵循的一种规则,这样更方便以后的代码维护,保证了代码的重用性Top
19 楼bobyisland()回复于 2005-09-17 09:56:49 得分 0
关注中~~~~Top
20 楼onlyxu(这么多OpenSource,为什么还要做软件?)回复于 2005-09-20 22:09:24 得分 0
搞通了就可以称之为框架
搞大了就可以称为平台Top
21 楼freedemon(自由魔鬼)回复于 2005-09-23 12:59:27 得分 0
"平台是程序运行所依赖的环境,而框架是建立在平台的基础之上一种通用的开发模式"
赞同。
“搞通了就可以称之为框架
搞大了就可以称为平台”
---有一点道理,但是平台和框架应该有一条清楚的界限,他们的根本职责不同。
“平台和框架没什么可比性”
-----有点没道理吧。虽然二者职责根本不同,但也有共性。平台比框架更抽象、跟基础。
Top
22 楼freedemon(自由魔鬼)回复于 2005-09-23 13:02:38 得分 0
应用程序与平台应是松耦合的,与框架是紧耦合的。这应该是评判标准Top
23 楼EdisonXP(Edison)回复于 2005-09-26 06:17:32 得分 0
偶也顶一个Top
24 楼wanggongming()回复于 2005-09-26 09:38:18 得分 0
平台是程序运行所依赖的环境,而框架是建立在平台的基础之上一种架构模式,架构模式是多种开发模式的组合.Top
25 楼HengHuan(山里人)回复于 2005-09-26 10:31:33 得分 0
帮顶一下
Top
26 楼yuer0(金欲)回复于 2005-09-28 09:48:04 得分 0
(因为csdn留言系统的缘故,我只能打同音字。)
平台就是------解方战挣中的华夏大地
框架就是------毛则东的战略(农村包围城市等等。。。)/蒋建石的战略(。。。)
模式就是------毛则东的战术(最著名的十六字方针。。。)/蒋建石的战术(。。。)
其实可以看出。
平台1----------〉n框架
平台1----------〉n模式
框架1----------〉n模式
平台,那没办法,只要你选择了他就只能整天围绕它来生活。当然,在计算机世界里就不一样了。什么都可以重新来过。
一个框架,就是一个阵营。你选择Struts那么你就Struts阵营。当然,你也可以投靠其它阵营
模式就像java中的精灵线程,渗透在周身全部。比方说你现在要和莫情敌PK,那么你就可以用毛住席的设计模式---十六字方针。完全可以搞定他。这也是对模式的阐释----可复用,固定步骤。
这是我的理解,希望能达到我预想的效果-----形象。Top
27 楼freedemon(自由魔鬼)回复于 2006-01-22 13:22:06 得分 0
还有人跟贴吗?再等几天否则结贴了
Top
28 楼kingofhawks(蓝鹰)回复于 2006-01-22 15:04:29 得分 0
这个版还有个贴是关于”架构和框架的区别“呵呵。Top
29 楼boltzjf(Bolt晶峰)回复于 2006-01-23 17:24:49 得分 0
我认为平台是从横向来看的,框架是从纵向来看的。
平台提供一些项目开发/二次开发的基础服务,在平台的基础上进行开发就是利用平台提供的一些基础服务,能够使开发更加迅速,或者有些平台甚至可以通过配置直接使用。
框架是对一个系统的结构而言的,系统分为哪些部分,各部分之间用什么样的协议进行配合工作。但是一般框架定义了各部分之间的交互方式,所以就有一些系统行为是公用的,可以作为基础服务,这样就使得框架和平台的概念有了容易混淆的地方。Top




