控制反转和依赖注入

控制反转和依赖注入

控制反转(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 对象),就需要自行保证线程安全。

应该怎么保证线程安全?

加锁

相关推荐