控制反转和依赖注入
控制反转(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 对象),就需要自行保证线程安全。
应该怎么保证线程安全?
加锁