SpringBoot中的IoC

SpringBoot中的IoC

(原创内容,转载请注明来源,谢谢)

一、Spring IoC

IoC又称为依赖反转,有两种方式,一种是DI(依赖注入),另一种是DL(依赖查找)。DI是当前实体被动依赖其他组件的IoC注入,DL是当前实体主动注册某个服务。

典型的Spring IoC方式如下:

ApplicationContextcontext = new FileSystemXmlApplicationContext(....);
MockServiceservice = context.getBean(MockService.class);
service.doSomething();

其中第二行的context.getBean就属于DL的过程,即主动去加载某个服务。但是构建IoC容器的背后,更多的是DI。

1、Spring IoC DI流程

1)收集和注册

第一阶段是构建和收集Bean,通常通过XML或者java代码的方式进行构建和定义。

2)分析和组装

收集和注册后,每个Bean都是一个独立的个体,则需要在这个阶段将每个bean联系起来,如果bean之间有依赖关系的,还需要进行依赖。

早期Spring可以通过xml进行此工作,但是Springboot中,更趋向于使用Annotation的方式,即@注解的方式。

2、Java Config

基于Java Config的方式,即对Annotation的完美实现。

1)表达形式层面

对于以前复杂的bean的xml的配置,现在可以用注解的方式来实现。对于定义一个类作为javaconfig,只需要在类的上方加上@Configuration,即将其定义成一个bean。

例如:

@Configuration
public class TestConfiguration{
//bean定义
}

2)注册bean定义层面

对于备注了Configuration内部的方法,加上@Bean,则将其标注成bean,其返回值将作为一个bean注册到Spring IoC容器,方法名默认称为该bean定义的id。

例如对于上述class,其中的某个类:

@Bean
publicTestService testService(){
return new TestServiceImpl();
}

3)表达依赖注入层面

对于某个bean,如果依赖于其他的bean,则只需要在该方法返回值的new构造方法中,传入所依赖的bean对应的方法即可。

例如对于上述方法,如果有一个方法依赖上述方法,则:

@Bean
publicDependencyService dependencyService(){
return new DependencyServiceImpl(testService());
}

4)优化

对于多个bean互相依赖,对于同一个类,并不会产生多个实例。

Spring boot通过拦截配置类避免多次初始化某个类。对于bean的依赖,会先查看拦截配置类是否已经实例化过该类,只有在没有实例化过该类的情况下,才会请求父类的同一方法来实现实例化。

——written by linhxx 2017.09.22

原文发布于微信公众号 - 决胜机器学习(phpthinker)

原文发表时间:2017-09-22

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Java Edge

IoC容器系列的设计与实现(基于Spring5.0.4)1 Spring的IoC容器系列2 Spring IoC容器的设计3 BeanFactory的应用场景4 BeanFactory容器的设计原理5

2946
来自专栏pangguoming

Hibernate详细教程

一、搭建Hibernate环境 1.在src目录下创建hibernate.cfg.xml配置文件 PS:文件的名字不能改! <?xml version="1.0...

3555
来自专栏JackieZheng

照虎画猫写自己的Spring——依赖注入

前言 上篇《照虎画猫写自己的Spring》从无到有讲述并实现了下面几点 声明配置文件,用于声明需要加载使用的类 加载配置文件,读取配置文件 解析配置文件,需要将...

1878
来自专栏Jackson0714

C#多线程之旅(1)——介绍和基本概念

2639
来自专栏小白鼠

Mybatis

从xml配置文件中读取配置,然后通过SqlSessionFactoryBuilder构建SqlSessionFactory实例(建造者模式)。SqlSessio...

1153
来自专栏曾大稳的博客

Glide v3.7源码分析(2)-----RequestManager.load

可以看到,Glide初始化的时候做了很多的事,初始化了缓存相关的类,任务执行以及缓存管理的引擎,注册了DataLoadProviderRegistry Gene...

641
来自专栏Java Edge

Java线程池-ThreadPoolExecutor源码解析(基于Java8)1 线程池的实现原理源码分析2 线程池的使用总结

4447
来自专栏coolblog.xyz技术专栏

Spring AOP 源码分析 - 创建代理对象

在上一篇文章中,我分析了 Spring 是如何为目标 bean 筛选合适的通知器的。现在通知器选好了,接下来就要通过代理的方式将通知器(Advisor)所持有的...

1367
来自专栏Java帮帮-微信公众号-技术文章全总结

Java多线程详解4【面试+工作】​

Java多线程详解【面试+工作】 Java线程:并发协作-死锁 线程发生死锁可能性很小,即使看似可能发生死锁的代码,在运行时发生死锁的可能性也是小之又小。 发生...

3309
来自专栏大闲人柴毛毛

Java并发编程的艺术(八)——闭锁、同步屏障、信号量详解

1. 闭锁:CountDownLatch 1.1 使用场景 若有多条线程,其中一条线程需要等到其他所有线程准备完所需的资源后才能运行,这样的情况可以使用闭锁。...

3284

扫描关注云+社区