spring bean是什么

60.9k Java , , 22评论

Spring有跟多概念,其中最基本的一个就是bean,那到底spring bean是什么?

Bean是Spring框架中最核心的两个概念之一(另一个是面向切面编程AOP)。 是否正确理解 Bean 对于掌握和高效使用 Spring 框架至关重要。 遗憾的是,网上不计其数的文章,却没有简单而清晰的解释。 那么,Spring bean 到底是什么? 接下来我们用图文方式来解析这一个概念。

1 定义

Spring 官方文档对 bean 的解释是:

In Spring, the objects that form the backbone of your application and that are managed by the Spring IoC container are called beans. A bean is an object that is instantiated, assembled, and otherwise managed by a Spring IoC container.

翻译过来就是:

在 Spring 中,构成应用程序主干并由Spring IoC容器管理的对象称为bean。bean是一个由Spring IoC容器实例化、组装和管理的对象。

概念简单明了,我们提取处关键的信息:

  1. bean是对象,一个或者多个不限定
  2. bean由Spring中一个叫IoC的东西管理
  3. 我们的应用程序由一个个bean构成

第1和3好理解,那么IoC又是什么东西?

2 控制反转(IoC)

控制反转英文全称:Inversion of Control,简称就是IoC。 控制反转通过依赖注入(DI)方式实现对象之间的松耦合关系。程序运行时,依赖对象由【辅助程序】动态生成并注入到被依赖对象中,动态绑定两者的使用关系。Spring IoC容器就是这样的辅助程序,它负责对象的生成和依赖的注入,让后在交由我们使用。 简而言之,就是:IoC就是一个对象定义其依赖关系而不创建它们的过程。 这里我们可以细分为两个点。

2.1 私有属性保存依赖

第1点:使用私有属性保存依赖对象,并且只能通过构造函数参数传入,构造函数的参数可以是工厂方法保存类对象的属性、或者是工厂方法返回值。 假设我们有一个Computer类:

public class Computer {
private String cpu;     // CPU型号
private int ram;        // RAM大小,单位GB

    public Computer(String cpu, int ram) {
        this.cpu = cpu;
        this.ram = ram;
    }
}

我们有另一个Person类依赖于Computer类,符合IoC的做法是这样:

public class Person {
    private Computer computer;

    public Person(Computer computer) {
        this.computer = computer;
    }
}

不符合IoC的做法如下:

// 直接在Person里实例化Computer类
public class Person {
    private Computer computer = new Computer(AMD, 3);
}

// 通过【非构造函数】传入依赖
public class Person {
    private Computer computer;

    public void init(Computer computer) {
        this.computer = computer;
    }
}

2.2 让Spring控制类构建过程

第2点:不用new,让Spring控制new过程。在Spring中,我们基本不需要 new 一个类,这些都是让 Spring 去做的。 Spring 启动时会把所需的类实例化成对象,如果需要依赖,则先实例化依赖,然后实例化当前类。 因为依赖必须通过构建函数传入,所以实例化时,当前类就会接收并保存所有依赖的对象。 这一步也就是所谓的依赖注入

2.3 这就是IoC

在 Spring 中,类的实例化、依赖的实例化、依赖的传入都交由 Spring Bean 容器控制, 而不是用new方式实例化对象、通过非构造函数方法传入依赖等常规方式。 实质的控制权已经交由程序管理,而不是程序员管理,所以叫做控制反转。

3 Bean?

至于bean,则是几个概念。

  • 概念1:Bean容器,或称spring ioc容器,主要用来管理对象和依赖,以及依赖的注入。
  • 概念2:bean是一个Java对象,根据bean规范编写出来的类,并由bean容器生成的对象就是一个bean。
  • 概念3:bean规范。

bean规范如下:

  1. 所有属性为private
  2. 提供默认构造方法
  3. 提供gettersetter
  4. 实现serializable接口

参考文章:

  1. Spring Dependency Injection
  2. Spring IoC, Spring Bean Example Tutorial
  3. The IoC Container – Spring docs
  4. What is a Spring Bean?
  5. What in the world are Spring beans?
  6. How to understand Bean in Spring?
  7. Java bean 是个什么概念?
  8. Spring中Bean及@Bean的理解

22 条评论

c
chn-student says: 回复

感谢您的耐心讲解!

j
jiushiyzl says: 回复

谢谢大佬!

小林 says: 回复

跪求求大佬解答一下图片的意思

says: 回复

很好 谢谢~! 大佬~!

r
rookiiie says: 回复

码了!唯独这个是看懂哒! 大佬我能转载链接吗

W
Will says: 回复

大佬,那方法前使用@Bean annotation修饰是怎么理解呢?
是这个类的主干方法,有着统一格式、去依赖性外部传入依赖对象的方法?

:
: > says: 回复

Thanks very much

纸上谈兵 says: 回复

新人,看着是懂了, 但是想一想还是云里雾里的。

b
benjamin says:

多看看设计模式,写代码绕不过去的,就是设计模式,另外一个就是英文。

S
Sea_Star says: 回复

这讲的也太好了吧

大郎该喝药了 says: 回复

感谢大佬,学spring框架前不懂,做完东西再回过头看就清晰多了

专门注册来感谢大佬 says: 回复

这个真心是好文,谢谢大佬。

f
fourteen says: 回复

虽然作为初学者还是有一点懵懂,但是已经感觉清晰很多!谢谢

n
niu says: 回复

终于找到一篇真正解释得了,其他的都直接术语堆上,该不懂还是不懂

M
MiraKangKang says: 回复

写的很优雅,赞

x
xiaoxigua says: 回复

大佬牛逼

B
Bing says: 回复

讲得真好!大佬牛逼!

小鱿鱼 says: 回复

您好,可以转载吗?

Q
Qingwei says: 回复

搜遍整个互联网,就您写的这篇文章我看懂了。简洁明了,直切主题!!佩服!

s
shz says: 回复

“依赖对象由【辅助程序】动态生成并注入到被依赖对象中?“ 这句话是不是说反了,还是我理解有问题?

不该是“被依赖对象由【辅助程序】动态生成并注入到依赖对象中?“ 吗??

z
zhz says: 回复

挖的阿瓦

s
shz says: 回复

dddd

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

昵称 *