代码改变世界

Spring也许在慢慢成为EJB

2011-04-15 16:18  卫佳  阅读(278)  评论(0编辑  收藏  举报

Spring也许在慢慢成为EJB

  • 依赖注入并不是不好,但Spring的依赖注入并不是很好,因为他要强迫很多人员了解别人的东西(你现在要用别人的一个接口,需要配置 Spring,那么你必然要找到该接口的实现类,甚至是多个实现类,需要了解别人内部的东西,这叫解耦吗),特别是开发人员水平不高的情况下,基本上就是 为了注入而注入,为了接口而接口。
  • Spring更合适在模块内部使用,但现在大部分开发人员都做不到模块化设计,而Spring大量的配置文件,将相关内容全局化了,进一步破坏了模块化设计的可能。
  • Spring的配置文件太多,而且基本上现在web开发中,都是全局化的,再加上autowire,维护难度远远大于代码。
  • 减少了静态编译的机制,增加了不必要的错误。
  • 占个位,慢慢补充。body brush


当然有人说,是很多人没有用来Spring,事实上,EJB也是这样,不是EJB不好,而是EJB没有被用好。
就好象API的设计,如果你设计了一个API,却很容易让人误用(或者是进行了错误的宣传),那么责任是使用者还是开发者呢?

大概在7年前,我就不太认同Spring,当然Spring不会因为我的不认同而停止,7年后,情况似乎更严重了。
我现在仍然想问一个问题:配置文件真的比代码更容易维护吗?

另外说一句,我反对Spring的思路,但是也会用到Spring的一些功能包,比如Jndi的封装等。enamel jewelry

估计很多人不同意我的意见,不过希望大家静心讨论一下。

另外说一句,“面向接口编程”,这话里的接口不是java的interface,如果真正翻译一下,应该是“面向抽象编程”,也就是说,将功能抽象出来,然后通过对外的内容提供功能,至于对外的内容是interface,还是class,要看具体的情况。
不是说我写了一个接口,再写一个实现类,就变成“面向接口编程”。
所以也提醒大家注意,回头看一下自己的代码,是否真地对自己的功能进行抽象了,如果说从interface中看出了非常具体的功能,那么这个interface其实就没有什么意义。