Spring 为啥默认把bean设计成单例的?这篇讲的明明白白的

简介: Spring 为啥默认把bean设计成单例的?这篇讲的明明白白的

熟悉Spring开发的朋友都知道Spring提供了5种scope分别是singleton、prototype、request、session、global session。

 

如下图是官方文档上的截图,感兴趣的朋友可以进去看看这五种分别有什么不同。今天要介绍的是这五种中的前两种,也是Spring最初提供的bean scope singleton 和 prototype。

 

Spring官方文档介绍如下图:

 

 

更多内容可以看官方文档介绍,非常详细:

https://docs.spring.io/spring/docs/3.0.0.M3/reference/html/ch04s04.html

 

单例bean与原型bean的区别

 

如果一个bean被声明为单例的时候,在处理多次请求的时候在Spring容器里只实例化出一个bean,后续的请求都公用这个对象,这个对象会保存在一个map里面。

 

当有请求来的时候会先从缓存(map)里查看有没有,有的话直接使用这个对象,没有的话才实例化一个新的对象,所以这是个单例的。但是对于原型(prototype)bean来说当每次请求来的时候直接实例化新的bean,没有缓存以及从缓存查的过程。

 

1、画图分析

 

 

2、源码分析

 

生成bean时先判断单例的还是原型的

 

 

如果是单例的则先尝试从缓存里获取,没有在新创建

 

 

结论:

 

  1. 单例的bean只有第一次创建新的bean 后面都会复用该bean,所以不会频繁创建对象。
  2. 原型的bean每次都会新创建

 

单例bean的优势

 

由于不会每次都新创建新对象所以有一下几个性能上的优势:

 

1、减少了新生成实例的消耗

 

新生成实例消耗包括两方面,第一,spring会通过反射或者cglib来生成bean实例这都是耗性能的操作,其次给对象分配内存也会涉及复杂算法。

 

2、减少jvm垃圾回收

 

由于不会给每个请求都新生成bean实例,所以自然回收的对象少了。

 

3、可以快速获取到bean

 

因为单例的获取bean操作除了第一次生成之外其余的都是从缓存里获取的所以很快。

 

有关bean实例化相关可以看着篇文章:

https://juejin.im/post/5ca42bfa6fb9a05e17799e07

 

单例bean的劣势

 

单例的bean一个很大的劣势就是他不能做到线程安全!!!,由于所有请求都共享一个bean实例,所以这个bean要是有状态的一个bean的话可能在并发场景下出现问题,而原型的bean则不会有这样问题(但也有例外,比如他被单例bean依赖),因为给每个请求都新创建实例。

 

关于这方面我正在准备写一篇文章,在整理当中,感兴趣的朋友可以关注我,我后续写一篇详细的文章。

 

总结

 

Spring 为啥把bean默认设计成单例?

 

答案:为了提高性能!!!从几个方面,

 

  1. 少创建实例
  2. 垃圾回收
  3. 缓存快速获取

 

单例有啥劣势?

 

如果是有状态的话在并发环境下线程不安全

相关文章
|
1月前
|
Java 测试技术 数据库连接
【Spring源码解读!底层原理高级进阶】【下】探寻Spring内部:BeanFactory和ApplicationContext实现原理揭秘✨
【Spring源码解读!底层原理高级进阶】【下】探寻Spring内部:BeanFactory和ApplicationContext实现原理揭秘✨
|
29天前
|
XML 缓存 Java
天天用 Spring,bean 实例化原理你懂吗
天天用 Spring,bean 实例化原理你懂吗
17 0
|
7月前
|
Java 程序员 Spring
Spring中bean类的生命周期|面试必问如何回答
Spring中bean类的生命周期|面试必问如何回答
|
4月前
|
缓存 Java Spring
面试官猛的一问:Spring的Bean注入如何解决循环依赖的?
面试官猛的一问:Spring的Bean注入如何解决循环依赖的?
138 0
|
5月前
|
Java Spring 容器
Spring源码:Bean生命周期(终章)
本系列前面讲解了Spring的bean定义、bean实例化、bean初始化等生命周期阶段。这些步骤使我们能够了解bean从创建到准备好使用所经历的过程。但是,除了这些步骤,bean的销毁也是非常重要的一步。在本系列的最后,我们将深入探讨bean的销毁过程,包括在什么情况下会发生销毁、销毁的顺序以及如何在bean销毁之前执行一些清理任务等。通过学习bean的销毁过程,我们将更全面地了解Spring的bean生命周期。在Spring中,有多种方式可以销毁bean。其中一种方式是在应用程序关闭时显式地调用`applicationContext.close()`方法来关闭容器。这个方法将会销毁所有还没
|
XML Java 数据格式
【Spring源码】讲讲Bean的生命周期
面试官:“看过Spring源码吧,简单说说Spring中Bean的生命周期”
272 1
【Spring源码】讲讲Bean的生命周期
|
XML 缓存 Java
面试官:讲讲Spring框架Bean的加载过程
面试官:讲讲Spring框架Bean的加载过程
651 0
面试官:讲讲Spring框架Bean的加载过程
|
Java Spring
一图搞懂Spring Bean载入ioc过程以及生命周期 ✨ 每日积累
一图搞懂Spring Bean载入ioc过程以及生命周期 ✨ 每日积累
一图搞懂Spring Bean载入ioc过程以及生命周期 ✨ 每日积累
扯一把 Spring 的三种注入方式,到底哪种注入方式最佳?
循环依赖这个问题,按理说我们在日常的程序设计中应该避免,其实这个本来也是能够避免的。不过由于种种原因,我们可能还是会遇到一些循环依赖的问题,特别是在面试的过程中,面试考察循环依赖,主要是想考察候选人对 Spring 源码的熟悉程度,因为要把循环依赖这个问题解释清楚,涉及到不少 Spring 源码。 今天松哥抽空和大家简单聊聊这个话题,问题比较庞大,我可能花几篇文章来和大家分享下,今天先来聊聊实例的注入方式。
|
XML Java 数据格式
这篇文章,我们来谈一谈Spring中的属性注入(2)
这篇文章,我们来谈一谈Spring中的属性注入(2)
136 0