<%@ page contentType="text/html; charset=gb2312"%> 开发框架:Java编程中Spring的一些负面因素
网站公告:   ◆北天JAVA技术网热情为java爱好者服务,本网内容包括JAVA(JSP、servlet、EJB、webservice、j2ee、javabean、应用服务器、JavaScript),数据库(MYSQL、SQL Server、Sybase、Oracle、DB2、数据库综合知识),设计研究(设计模式、Struts、Spring、Hibernate、设计框架、设计综合知识),WEB2.0新技术(主要介绍AJAX),以及各种技术的入门、实例、例子等等,欢迎各位多来坐坐!◆  诚邀各位JAVA爱好者加盟!◆  本网站内容丰富,更新快,保证每周20篇以上!  
加入收藏
设为首页
联系站长
承接项目
  相关资源:网站首页 | 免费培训学院 | 技术论坛 | JAVA聊天室 | 作家专栏 | 开发工具 | 认证考试 | 会员俱乐部
  JAVA技术初学者园地 | jsp与servlet | javascript | Java源代码 | EJB | web service | 应用服务器 | JAVA综合知识
  设计研究设计模式 | 设计框架 | Struts | Spring | Hibernate | 开源项目 | 面向对象设计 | 设计综合知识
  数 据 库MYSQL | SQL Server | Sybase | Oracle | DB2 | Informix | Access | 数据库综合知识
  其他资源:AJAX新技术 | 网站开发 | ERP软件 | OA办公软件 | 商业智能BI | 开发综合知识 | 承接项目 | 项目试用

 
 
开发框架:Java编程中Spring的一些负面因素
     发布者: 发布时间:2008-04-24
最近一直在忙于学习业务系统和学习c++,对技术框架已经疏于了解。恰好一同事在我项目里使用了spring,并带了些问题,所以决定看看Spring技术,针对我同事带来的这些问题与大家讨论。


主要是些负面的体会。


一。Spring的xml配置很不好。xml滥用程度已经泛滥成灾了。要知道程序员最习惯,最欢迎的还是看代码。当要看一个业务逻辑时发现竟然先要去看它的父类,然后看爷爷类,然后再看太爷爷类,最后发现还需要找Spring配置去找另外一个类,而这个类ref了另外一个类时,肯定哐当晕倒。无论是初学语言,还是对技术深入了解的高手,或者还是因为项目紧急从别的地方抽掉过来的其他成员。简单的代码和配置都是合适的(像我这样用了好几年的java的人已经有点不爱看xml配置)。


二。Spring的配置方式不支持开发模式。每次修改Spring配置,总是需要重启动。一些大项目启动是非常耗时的。相反一些别的小的第三方配置开发包可以支持开发模式。另外,我觉得Sping也不太可能支持开发模式,这在下面一点会说到


三。直觉上Spring管的太多。对于很多框架或者第三方lib来说,往往专著于完成系统的某一方面。如Hibernate专著于O/R Mapping,EJB专著于分布,事务,规则引擎专著于解释规则,执行运算等。Spring做的太多使其有啥都做不好的嫌疑,当然这还不是最主要的负面因素,而是他干扰了业务系统。他对对象进行管理有可能会让某些用户用Spring管理业务对象。这有可能带来负面结果的。如一些情况:Struts的 MVC被Spring接管,业务逻辑又被Spring接管。一个
新手很难看懂代码。了解代码的时候总会遇到“黑洞”。又如上面所说的开发模式,因为业务对象的互相依赖,"重新启动业务对象"是很复杂的一件事情,Spring也不可能做到这一点。除非你的业务对象屈服于Spring的架构,这又和使用 Spring初衷违背了。再如,业务对象的复杂性,核心性决定了Spring难以管理好它,也没有必要多此一举.


四。适配器成灾。Spring为了管理好第三方包,只好做些适配器。以方便管理。当然,有些第三方包很简单,不需要做,比如我看到javaresearch.org刚有的一篇文章是在Spring中使用定时器。但是某些复杂的第三方包或者框架就有问题了,得写适配器。如接管某web mvc框架。又如刚才所说的定时器lib,本生功能齐备的定时器lib就有自己的配置,你要去Spring去管理它。只能写个适配器,在适配器中使用定时器lib提供的配置文件。



(转载文章请保留出处:北天JAVA技术网(www.java114.com))
 
更多精彩文章:
Eclipse插件开发中实现刷新和重编译介绍
Java编程那些事儿15——如何学好Java语法
关于Java Socket编程的详细介绍
Java编程语言在软件开发中的几个认识误区
使用Java Annotations来管理对象生命周期
Abstractclass和Interface在Java中的应用
 
最近评论:
        
鍥炲
        
标 题:   
内 容:   
 
                                  
 
免责声明:该文章由网友发表,如果对您造成侵权,请联系站长

首页 - 承接项目 - 网站地图 - 联系我们 -
版权所有北天JAVA技术工作室 ICP证号:粤ICP备06079815号