CSDN首页 空间 新闻 论坛 Blog 下载 读书 网摘 搜索 .NET Java 视频 接项目 求职 在线学习 买书 程序员 通知
不看会后悔的Windows XP之经验谈 简单快捷DIY实用家庭影院
CSDN社区
搜索 收藏 打印 关闭
CSDN社区 >  Java >  架构、设计

[讨论]什么是平台,什么是框架?二者区别何在?

楼主freedemon(自由魔鬼)2005-07-20 21:37:27 在 Java / 架构、设计 提问

当前平台、框架的概念十分流行。很多公司都有自己的平台或者开发框架,搞得我是都不知道什么是平台什么是框架了.  
  大家讨论一下,自己的看法。 问题点数: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

相关问题

  • 在网上找到一个跨平台(Win32,Linux,Unix,MacOS)多线程框架:zThread,望大家讨论使用方法
  • 讨论:模式、框架
  • 如何在框架中传值
  • 如何在框架中是用按钮?
  • 如何在ASP.NET中设计框架?
  • 如何在框架中关闭IE?
  • ERP平台开发(讨论)
  • java框架的明天(讨论)
  • 如何在一个框架里同时按制别外两个框架
  • 如何在T型框架的任何一个页面内让主框架更新。

关键词

  • j2ee
  • 框架
  • 平台
  • 模式
  • 架构
  • 设计模式
  • 软件
  • 耦合
  • 系统
  • 应用

得分解答快速导航

  • 帖主:freedemon

相关链接

  • CSDN Java频道
  • Java类图书
  • Java类源码下载

广告也精彩

反馈

请通过下述方式给我们反馈
反馈
提问
网站简介|广告服务|VIP资费标准|银行汇款帐号|网站地图|帮助|联系方式|诚聘英才|English|问题报告
北京创新乐知广告有限公司 版权所有, 京 ICP 证 070598 号
世纪乐知(北京)网络技术有限公司 提供技术支持
Copyright © 2000-2008, CSDN.NET, All Rights Reserved
GongshangLogo