控制反转和依赖注入

前端之家收集整理的这篇文章主要介绍了控制反转和依赖注入前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

控制反转和依赖注入

控制反转(Inversion of Control,Ioc)

应用本身不负责依赖对象的创建及维护,依赖对象的创建及维护由外部容器来负责。这样控制权就由应用转移到了外部容器,控制权的转移就是所谓反转。

依赖注入(Dependency Injection)

在运行期间,有外部容器动态地将依赖对象注入到组件中(构造方法和set方法)

三种依赖注入的方式

1. settter方法注入

2. 构造函数方式注入

3. 使用@autowire或者@resource注解进行注入。(最常用的方法

三种装配bean的方式

1. xml配置文件

2. 注释

3. Java类配置

bean的作用域

1. singleton:当一个bean的作用域为singleton,那么Spring IoC容器中只会存在一个共享的bean实例,并且所有对bean的请求,只要id与该bean定义相匹配,则只会返回bean的同一实例。

2. prototype:一个bean定义对应多个对象实例。Prototype作用域的bean会导致在每次对该bean请求(将其注入到另一个bean中,或者以程序的方式调用容器的getBean()方法)时都会创建一个新的bean实例。

3. request:在一次HTTP请求中,一个bean定义对应一个实例;即每次HTTP请求将会有各自的bean实例, 它们依据某个bean定义创建而成。该作用域仅在基于web的Spring ApplicationContext情形下有效。

4. session:在一个HTTP Session中,一个bean定义对应一个实例。该作用域仅在基于web的Spring ApplicationContext情形下有效。

5. global session:在一个全局的HTTP Session中,一个bean定义对应一个实例。

设置方法如下:

<bean id="empServiceImpl" class="cn.csdn.service.EmpServiceImpl" scope="singleton">

spring框架中的单例bean是线程安全的吗?

不是

Spring框架并没有对单例bean进行任何多线程的封装处理。关于单例bean的线程安全和并发问题需要开发者自行去搞定。但实际上,大部分的Spring bean并没有可变的状态(比如Serview类和DAO类),所以在某种程度上说Spring的单例bean是线程安全的。如果你的bean有多种状态的话(比如 View Model 对象),就需要自行保证线程安全。

应该怎么保证线程安全?

加锁

猜你在找的设计模式相关文章