我没有使用Spring

翻译 2006年02月07日 20:30:00
                                                                我没有使用Spring
                                                                                     作者: Bob Lee
 
 
在这里,Spring指的是Spring开发框架,一种依赖注入容器的实现。首先,我声明我没有一点冒犯Rod的意思(你是个优秀的人)。但是坦白地说,我不能狂热的追随您的开发框架。更为严重的是,我注意到,我所考虑的这些可能对于Spring框架的使用率来说是危险的,并且有可能降低对Spring框架的使用率。我读到一个关于Spring的很重要的文章或书籍,看起来好像除了我,所有的人都喜欢Spring。但是我有什么损失吗?可能采用Spring是J2EE一个类似“膝跳反射”的事情(这种事情可以不经过大脑)。“J2EE不是好东东,Spring的人说他们的产品更好一些,所以Spring一定是好的”但是事情并不是那样的。
第二点,我仅仅讨论Spring,而不讨论依赖注入。我喜欢依赖注入,并且每天都使用它。它是一个摆脱service locators的好方法。
我记不得有多少次有开发者对我说,“我的上一个项目使用了Spring,这个框架真好”。但是没有人能清楚明白的说出他们究竟喜欢Spring的哪一点,Spring到底帮助了他什么。所以我敢说,他们喜欢setter注入,这使得他们的代码更加灵活和可测;但并不一定必需Spring。我猜有些人并没有彻底理解依赖注入,所以他们依赖Spring来帮助(或者强迫?)他们使用依赖注入。然而,这种好处并没有在量上大于Spring在你的代码上带来的负面影响,这些负面相应在下面的清单上。
Spring的狂热者公开的指责J2EE,但是从他们的指责中,我可以说,Spring实际上既不是轻量级也不简单。Javadocs未必是必要的,但是这一切都要怪罪于一个用户API吗?最起码J2EE清晰的将API和它们的实现分离开来。Spring的鼓吹者吹捧Spring不会“动”你的代码,例如,你不必去实现任何的Spring指定的接口(生命周期接口除外等等)。新闻特写,“XML配置文件是我们自己的代码,通过它,我们能组织起很多的代码,这些代码都是Spring给定的”
为什么我一定要把我所有的依赖使用XML文件来表达?我是需要把我所有的对象都用Spring来处理,还是仅仅一些没有考虑成熟的?上面我所说的这些问题,Spring文档没有给出一些可靠的答案,而且所有的Spring书籍也没有给出。我假定我们使用Spring是为了产生所有的对象。那么这样还是我们喜欢的Java编程吗?我希望在编译期和随后的装载期能够确定这些对象,而不是在运行我的代码的时候才能够确定。Spring能做到支持这些吗?
很明显,我希望装载一些像JDBC驱动这样的动态实现的依赖(即不要求编译期的检测);但是在我的系统中,这样的依赖只是一小部分;而剩下的部分,我们代码的绝大部分却不是。我是在使用一种强类型的语言。如果我希望像Spring那样,我会使用Ruby。难道Spring的配置文件不像是我们在猜测着将Java代码写入XML文件里吗?难道那些使用Spring的开发者使用起Java来不那么舒服?我确信增加了一个XML层并不能使得代码变得哪怕是一点点简单。
现在回过头来谈谈关于对Spring API的依赖的问题。我不得不调用容器来产生我的第一个对象(假定剩下的Spring管理对象是注入的),不是吗?我需要一些方法在编译期间来测试我所请求的对象是正确的类型;我不想靠抛出违例的方法。究竟,我真的需要一个容器吗?在Spring里,你通过使用一个唯一的ID来获取对象。我假定大部多数的开发者在他们Java代码里使用一个String类型的常量来定义他们的ID。Spring并不能帮助我使得我的Java代码里的ID值和我的XML文件里的ID值保持一致。当一个对象已经够用了的时候,为什么要使用两个对象?是否我们真的把所有的信息组织到一起放到了容器里?是Java的包和类不够用了吗?
还有一个困扰我的问题是,在我的XML配置文件里,我不得不引用Spring实现的类,我不想管这些东西。在Spring的计划里,我听说更加简单的、域范围的XML将在2.0版本中被使用,但是我到现在还没有看到。为什么这些不能早一点被采用呢?
什么继承上的东西啊?关于超常类名置换的变换。但这些都不是我的风格。
Spring在哪里支持了JDK1.5的泛型?我知道你有很多客户运行在JDK1.4甚至JDK1.3的版本上,但是这和JDK1.5没有分歧啊。泛型打开了通向像这种框架的各种各样的可能性的大门。这些是我最喜欢的JDK1.5的新特性,拥抱这些新特性吧!
你曾经看过每次你产生一个对象Spring要做多少事情吗?我需要在运行期内有少量的instanceof,而大多数是在装载期的Class.isAssignableFrom()。不是因为内部的实现给最终用户带来了很多的麻烦,而是因为把它作为了一个测试框架剩下部分质量的试金石。一个好的对于bean的创建渠道的重构将会很容易的被遵循和产生更加高质量的代码,并且不需要求助于更多的继承就能被重用。
Auto-wiring也有同样的问题。每一个人真的在使用它吗?或者是为未来的重要功能的一个铺垫?

Spring是怎么处理领域范围的?我听说在2.0版本中,Spring最终会支持HTTP request和session的。我很惊讶难道现在这些没有被支持吗,那么Spring的用户在整个期间里都做了些什么。难道是新的版本将使我能够定义自己的领域范围?例如,它将实现我想要一个“conversation”领域范围,就像Seam将要支持的那样。

我们将不涉及MVC或者AOP框架。幸运或者不幸的是在某一时候,我将不使用一个依赖注入容器。难道不认为PicoContainer已经远离了简单二字。它也和Spring有同样的问题,我认为Aslak和Jon已经转移到了Ruby的领地。还有其他的开发框架没有这样的问题吗?
幸运地,简单的采用依赖注入设计模式能让你完成Spring的90%的工作,特别是当你在并不急于使用它的时候。这是我推荐的方法。我的确没有看到让我自己马上使用Spring的理由。没有它我工作的很好。如果你在使用它,那么请你把眼睛睁大一些,使用怀疑的、鉴赏的目光。如果仅仅因为某人有流行的开源框架,他们有很好的市场,并且他们被一些大的公司支持(IBM在很多年前就推荐我使用Struts)。但这并不意味着他们知道什么工具对你最好,尽管他们比你知道什么是更好的。
原文链接:
http://crazybob.org/2006/01/i-dont-get-spring.html

Spring配置文件没有自动提示解决

使用各种xml配置文件时,都需要添加相应的约束规则,有时候会出现不会自动提示,以Spring注解开发为例。...
  • leisure_life
  • leisure_life
  • 2017-03-30 10:00:35
  • 5401

Spring是什么

1.1.1.Spring是什么 Spring是一个开源的轻量级Java SE(Java 标准版本)/Java EE(Java 企业版本)开发应用框架,其目的是用于简化企业级应用程序开发。应用程序是...
  • lp1052843207
  • lp1052843207
  • 2016-04-26 19:00:30
  • 14988

我没有使用Spring

                                                                我没有使用Spring                       ...
  • itkbase
  • itkbase
  • 2008-03-11 15:36:00
  • 132

解决Myeclipse编写SpringXML没有提示的问题

最近在学习Spring时使用编辑器Myeclipse没有代码提示功能 , 原因是没有添加与配置Spring-beans-3.2.xsd 做一下记录 ,大家也可以参考一下.步骤一:确定xsd文件位置sp...
  • qq994018859
  • qq994018859
  • 2018-03-05 21:07:05
  • 44

史上最全的java spring注解,没有之一

注解是个好东西,但好东西我们也是看见过,整理过,理解过,用过才知道好。不求我们每个都记住,但求保有印象,在需要的时候能提取出来再查找相关资料,平时工作就不会显得那么被动了。1.@Configurati...
  • achenyuan
  • achenyuan
  • 2017-05-27 23:23:59
  • 4866

Spring框架入门(一)

Spring 框架概述 1.1. 什么是Spring Spring是分层的JavaSE/EE full-stack(一站式) 轻量级开源框架 分层: 来自JavaEE体系结构 (客户端层、...
  • zxiang248
  • zxiang248
  • 2016-06-29 20:39:24
  • 21538

<constructor-arg>标签不可出现属性“name”可能是你spring版本过低

我在。spring拷贝配置文件时候 spring的构造注入编译器突然提示:构造注入不能有name 属性。上网查了下。发现是自己的spring版本的问题: 解决办法: 把xml的表头改为: ...
  • qq_27727251
  • qq_27727251
  • 2017-07-02 11:45:21
  • 154

spring的配置文件applicationContext中没有快捷键问题

这个对于很多xml格式的配置文件编辑很有帮助,以spring配置文件为例:   myeclipse的童鞋进入:window -> Preferences-> MyEclipse -> Edito...
  • wangqing84411433
  • wangqing84411433
  • 2017-05-27 23:13:46
  • 1196

问题解决——SpringMVC

写了一段代码,被提示 Model object must not be null] with root cause花了很长时间调试都没能解决,最坑的是加入了System.out.println(“”)...
  • fonxian
  • fonxian
  • 2015-06-26 21:49:39
  • 1104

Spring MVC 无XML配置入门示例

Spring MVC 无XML(纯 Java)配置入门示例 本示例是从《Spring in Action, Fourth Edition》一书而来,涉及的是书中5.1节部分内容,书中其实说的很详细...
  • classicer
  • classicer
  • 2016-02-26 23:18:15
  • 7012
收藏助手
不良信息举报
您举报文章:我没有使用Spring
举报原因:
原因补充:

(最多只允许输入30个字)