一、SpringIOC发展史
1. 当一个学生选修多个课程,而每个课程对应方法都各不相同,原先办法是必须每新增一个课程,就需要new一个课程对象,导致代码非常零散,造成后期维护麻烦。
2.简单工厂模式,将new的对象统一放到一个方法里面,可以将new集中操作,后期维护方便。
3.由于简单工厂需要自己创建而且不够彻底,因此发展出了SpringIOC容器。超级工厂,可以容纳任何对象。
&&SpringIOC容器相较于自定义工厂模式最大的优势是什么?
在工厂中修改就得重新编译工厂类,机子上还得装着JDK。在XML中修改只要一个Text编辑器就搞定了。重新编译以后你要用新编译的类得先停了JVM再重新启动,热插拔就是说你把XML改了spring就立刻发觉你改动了XML,重新读一遍XML,就会用你的新改动了,根本不用重新启动JVM。
比如你一个做生意的网站,热插拔意味着你的网站根本不用重启,客户几乎察觉不到有变动,你重启JVM,客户那边就要吃“网站正在维护”之类的闭门羹,这两者之间的区别可是天差地别啊。
二、IOC——Inversion Of Control 控制反转、Dependency Input依赖注入
1.基本概念
控制反转:反转的是获取对象的方式。new,setXxz - > getBeans创造 - > 获取
依赖注入:属性值注入->属性->对象(底层是反射)
&&IOC定义一个bean必须保证该类有无参构造
2.IOC容器三种方式的依赖注入
a.8个基本数据类型+String——value
b.对象——ref(实现了对象与对象之间的依赖关系)
(1)set注入(赋值默认使用的是set方法)
<property name="xxx" value="xxx"></property>
(2)构造器注入(构造方法赋值)
<construct-arg></construct-arg>默认要和构造方法参数顺序严格一致,
如果不一致,则需要通过指定参数类型type或者给定index(0开始)
(3)p命名空间注入(直接在bean标签上p)
a.简单类型
p:属性名=“属性值”
b.引用类型(String除外)
p:属性名-ref=“引用的id”
3.各种集合类型的依赖注入,略
4.特殊类型的依赖注入
(1)赋空值
<property name="xxx">
<null/>
</property>
(2)
<property value="xxx"></property>和
<property><value type=“int”>xxx</value></property>
a.如果参数需要引号的
b.如果需要指定type
(3)属性值含有< 可以用<表示。
(4)<![CDATA[<这里写什么都可以>&]]>
(5)自动装配:约定优于配置
<bean autowire ="byName">只对ref有效,会自动装配引用类型
a. byName本质是byId, 自动寻找:其他bean的id值=该Course类的属性名
b. byType: 其他bean的类型(class) 是否与 该Course类的ref属性类型一致 (注意,此种方式 必须满足:当前Ioc容器中 只能有一个Bean满足条件 )
c. constructor: 其他bean的类型(class) 是否与 该Course类的构造方法参数 的类型一致;此种方式的本质就是byType
d. 可以在头文件中 一次性将该ioc容器的所有bean 统一设置成自动装配:
<beans xmlns="http://www.springframework.org/schema/beans" default-autowire="byName">
f. 自动装配虽然可以减少代码量,但是会降低程序的可读性,使用时需要谨慎。
三、使用注解定义bean
——通过注解的形式 将bean以及相应的属性值 放入ioc容器
1.具体步骤:
<context:component-scan base-package="com.feng.dao,com.feng.service"></context:component-scan>
--Spring在启动的时候,会根据base-package在 该包中扫描所有类,查找这些类是否有注解@Component("studentDao"),如果有,则将该类加入SpringIOC容器。
2.分类
@Component细化:
dao层注解:@Repository
service层注解:@Service
控制器层注解:@Controller