草庐IT

java - 有没有Spring,性能有没有提升

coder 2024-03-22 原文

我的同行总是强制我使用 Spring 来创建任何对象的新实例。据我了解,Spring 提供了一个平台来更有效地管理业务对象。 Spring 使架构更加模块化和更加灵活。

在某些情况下,我觉得不使用 spring bean,而是使用创建新对象的通用方法。但是,我的同事们总是以提高绩效为借口强制我这样做。我从来没有找到任何与 spring 相关的文章提到性能因素。

问题: 如果我使用 spring bean 创建对象,与使用“new”运算符创建新实例相比,它是否提高了性能。

最佳答案

Spring 是一种与其他工具一样的工具 - 如果应用得当,它会带来好处。如果应用不当,它只不过是纯粹的开销。

这恰好是我在 Spring 中经常看到的常见情况 - 项目规定一切都必须是 Spring Bean。当人们试图做一些简单的事情时,这会导致开发工件方面的大量开销。

我发现在许多使用 Spring 的应用程序中遗漏的关键点围绕着设计人员/架构师普遍缺乏面向对象的经验或知识。他们对 Spring 很满意,因此一切都必须是 Spring。这种情况通常可以通过查看应用程序的整体类层次结构来识别(如果可以的话——我不知道有任何理解 Spring bean 的 UML 工具)——你通常会发现一个几乎平坦的继承层次结构——几乎没有类将从基类继承功能。这反过来意味着很少甚至没有封装。这反过来将表现为解决方案中的异常数量的类。最后,在我看到的大多数情况下,以这种方式使用 Spring 的应用程序也存在性能问题——不是因为使用了 Spring,而是更多的是缺乏全面的设计。 Spring 是一个框架,而不是一个架构。

Spring 唯一有意义的领域是可能经常更改或与执行环境相关的类 - 即测试与生产。除了那些领域之外,存在于问题域(现实)中的类之间的关系也应该存在于代码中——这些不会改变并且使它们成为 Spring bean 只会增加性能和开发工件方面的开销。

如果您的应用程序架构良好(在大多数情况下可能并非如此),那么任何库或框架都将始终由问题域中的类封装。这具体意味着库或框架在应用程序级别不是可见组件。这对于具有任何 OOA/OOD 意识的任何人来说都应该是显而易见的——您能想到商业世界中的一个单一问题域,它正式包括在外部配置类之间关系的能力。如果您回答是,那么您不了解 OOA/OOD,您将成为到处使用 Spring 的人之一。

这是一个试金石,供您查看您是否过度使用或错误地使用 Spring - 从理论上讲,您可以用类似的东西替换 Spring 而无需更改您的代码吗?如果不是,那么你的设计很薄弱,并且正在用 Spring 来支撑它。如果您的应用程序的每次发布都会增加您的责任(增加您的工作量),这通常是可以识别的。

最后,有人会赞同“Spring 让测试变得简单”的说法。对于大多数情况都是如此——大多数情况都是应用程序设计不当的一部分。唯一比构建在 Spring 上的应用程序更容易测试的是构建在设计良好的面向对象架构上的应用程序。

关于java - 有没有Spring,性能有没有提升,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10169852/

有关java - 有没有Spring,性能有没有提升的更多相关文章

  1. ruby - 难道Lua没有和Ruby的method_missing相媲美的东西吗? - 2

    我好像记得Lua有类似Ruby的method_missing的东西。还是我记错了? 最佳答案 表的metatable的__index和__newindex可以用于与Ruby的method_missing相同的效果。 关于ruby-难道Lua没有和Ruby的method_missing相媲美的东西吗?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/7732154/

  2. ruby-on-rails - rails 目前在重启后没有安装 - 2

    我有一个奇怪的问题:我在rvm上安装了ruby​​onrails。一切正常,我可以创建项目。但是在我输入“railsnew”时重新启动后,我有“程序'rails'当前未安装。”。SystemUbuntu12.04ruby-v"1.9.3p194"gemlistactionmailer(3.2.5)actionpack(3.2.5)activemodel(3.2.5)activerecord(3.2.5)activeresource(3.2.5)activesupport(3.2.5)arel(3.0.2)builder(3.0.0)bundler(1.1.4)coffee-rails(

  3. ruby - 在没有 sass 引擎的情况下使用 sass 颜色函数 - 2

    我想在一个没有Sass引擎的类中使用Sass颜色函数。我已经在项目中使用了sassgem,所以我认为搭载会像以下一样简单:classRectangleincludeSass::Script::FunctionsdefcolorSass::Script::Color.new([0x82,0x39,0x06])enddefrender#hamlengineexecutedwithcontextofself#sothatwithintemlateicouldcall#%stop{offset:'0%',stop:{color:lighten(color)}}endend更新:参见上面的#re

  4. java - 等价于 Java 中的 Ruby Hash - 2

    我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/

  5. ruby-on-rails - 带 Spring 锁的 Rails 4 控制台 - 2

    我正在使用Ruby2.1.1和Rails4.1.0.rc1。当执行railsc时,它被锁定了。使用Ctrl-C停止,我得到以下错误日志:~/.rvm/gems/ruby-2.1.1/gems/spring-1.1.2/lib/spring/client/run.rb:47:in`gets':Interruptfrom~/.rvm/gems/ruby-2.1.1/gems/spring-1.1.2/lib/spring/client/run.rb:47:in`verify_server_version'from~/.rvm/gems/ruby-2.1.1/gems/spring-1.1.

  6. java - 从 JRuby 调用 Java 类的问题 - 2

    我正在尝试使用boilerpipe来自JRuby。我看过guide从JRuby调用Java,并成功地将它与另一个Java包一起使用,但无法弄清楚为什么同样的东西不能用于boilerpipe。我正在尝试基本上从JRuby中执行与此Java等效的操作:URLurl=newURL("http://www.example.com/some-location/index.html");Stringtext=ArticleExtractor.INSTANCE.getText(url);在JRuby中试过这个:require'java'url=java.net.URL.new("http://www

  7. 没有类的 Ruby 方法? - 2

    大家好!我想知道Ruby中未使用语法ClassName.method_name调用的方法是如何工作的。我头脑中的一些是puts、print、gets、chomp。可以在不使用点运算符的情况下调用这些方法。为什么是这样?他们来自哪里?我怎样才能看到这些方法的完整列表? 最佳答案 Kernel中的所有方法都可用于Object类的所有对象或从Object派生的任何类。您可以使用Kernel.instance_methods列出它们。 关于没有类的Ruby方法?,我们在StackOverflow

  8. ruby-on-rails - Rails 3,嵌套资源,没有路由匹配 [PUT] - 2

    我真的为这个而疯狂。我一直在搜索答案并尝试我找到的所有内容,包括相关问题和stackoverflow上的答案,但仍然无法正常工作。我正在使用嵌套资源,但无法使表单正常工作。我总是遇到错误,例如没有路线匹配[PUT]"/galleries/1/photos"表格在这里:/galleries/1/photos/1/edit路线.rbresources:galleriesdoresources:photosendresources:galleriesresources:photos照片Controller.rbdefnew@gallery=Gallery.find(params[:galle

  9. ruby-on-rails - 有没有办法为 CarrierWave/Fog 设置上传进度指示器? - 2

    我在Rails应用程序中使用CarrierWave/Fog将视频上传到AmazonS3。有没有办法判断上传的进度,让我可以显示上传进度如何? 最佳答案 CarrierWave和Fog本身没有这种功能;你需要一个前端uploader来显示进度。当我不得不解决这个问题时,我使用了jQueryfileupload因为我的堆栈中已经有jQuery。甚至还有apostonCarrierWaveintegration因此您只需按照那里的说明操作即可获得适用于您的应用的进度条。 关于ruby-on-r

  10. java - 我的模型类或其他类中应该有逻辑吗 - 2

    我只想对我一直在思考的这个问题有其他意见,例如我有classuser_controller和classuserclassUserattr_accessor:name,:usernameendclassUserController//dosomethingaboutanythingaboutusersend问题是我的User类中是否应该有逻辑user=User.newuser.do_something(user1)oritshouldbeuser_controller=UserController.newuser_controller.do_something(user1,user2)我

随机推荐