34.1 常用 IOC 按作用分类
34.1.1 用于创建对象的
- 用于创建对象的: 作用和在XML配置文件中编写一个
<bean>
标签实现的功能是一样的 - Component:
- 作用: 用于把当前类对象存入spring容器中
- 属性:
- value:用于指定bean的id。当我们不写时,它的默认值是当前类名,且首字母改小写。
- Controller:一般用在表现层
- Service:一般用在业务层
- Repository:一般用在持久层
- notes:
- 以上三个注解他们的作用和属性与Component是一模一样;
- 他们三个是spring框架为我们提供明确的三层使用的注解,使我们的三层对象更加清晰;
- 细节:如果注解中有且只有一个属性要赋值时,且名称是 value,value 在赋值是可以不写。
- 示例:
- bean.xml 配置文件
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd">
<!--告知spring在创建容器时要扫描的包,配置所需要的标签不是在beans的约束中,而是一个名称为
context名称空间和约束中-->
<context:component-scan base-package="com.itheima"></context:component-scan>
</beans>
package com.itheima.service.impl;
import com.itheima.dao.IAccountDao;
import com.itheima.service.IAccountService;
import org.springframework.stereotype.Component;
/**
* 账户的业务层实现类
*/
//@Controller(value="accountService")
//@Service(value="accountService")
//@Repository(value="accountService")
@Component(value="accountService")
public class AccountServiceImpl implements IAccountService {
private IAccountDao accountDao ;
public AccountServiceImpl(){
System.out.println("对象创建了");
}
public void saveAccount(){
accountDao.saveAccount();
}
}
34.1.2 用于注入数据的
- 用于注入数据的: 他们的作用就和在xml配置文件中的bean标签中写一个标签的作用是一样的
- Autowired:
- 作用: 自动按照类型注入。只要容器中有唯一的一个bean对象类型和要注入的变量类型匹配,就可以注入成功
- 如果ioc容器中没有任何bean的类型和要注入的变量类型匹配,则报错。
- 如果Ioc容器中有多个类型匹配时: 使用要注入的对象变量名称作为 bean 的 id,在 spring 容器查找,找到了也可以注入成功。找不到
就报错。 - 出现位置: 可以是变量上,也可以是方法上
- 细节: 在使用注解注入时,set方法就不是必须的了。
- Qualifier:
- 作用:在按照类中注入的基础之上再按照名称注入。它在给类成员注入时不能单独使用。但是在给方法参数注入时可以。
- 属性:
- value:用于指定注入bean的id。
- 示例:
@Service("accountService")
//@Scope("prototype")
public class AccountServiceImpl implements IAccountService {
@Autowired
@Qualifier("accountDao1")
private IAccountDao accountDao = null;
}
- Resource
- 作用:直接按照bean的id注入。它可以独立使用
- 属性:
- name:用于指定bean的id。
- 示例:
@Service("accountService")
public class AccountServiceImpl implements IAccountService {
@Resource(name = "accountDao2")
private IAccountDao accountDao = null;
}
-
notes:
- Autowired、Qualifier、Resource三个注入都只能注入其他bean类型的数据,而基本类型和String类型无法使用上述注解实现。
- 集合类型的注入只能通过XML来实现。
示例:
-
Value
- 作用:用于注入基本类型和String类型的数据
- 属性:
- value:用于指定数据的值。它可以使用spring中SpEL(也就是spring的el表达式)
- SpEL的写法:
${表达式}
- SpEL的写法:
- value:用于指定数据的值。它可以使用spring中SpEL(也就是spring的el表达式)
34.1.3 用于改变作用范围的
- 用于改变作用范围的:他们的作用就和在bean标签中使用scope属性实现的功能是一样的
- Scope
- 作用:用于指定bean的作用范围
- 属性:
- value:指定范围的取值。常用取值:singleton prototype
34.1.4 和生命周期相关
- 和生命周期相关: 他们的作用就和在bean标签中使用init-method和destroy-methode的作用是一样的。
- PreDestroy
- 作用:用于指定销毁方法
- PostConstruct
- 作用:用于指定初始化方法
/**
* 账户的业务层实现类
*/
@Service(value="accountService")
@Scope("prototype")
public class AccountServiceImpl implements IAccountService {
// @Autowired
// @Qualifier("accountDao1")
@Resource(name = "accountDao2")
private IAccountDao accountDao = null;
@PostConstruct
public void init(){
System.out.println("初始化方法执行了");
}
@PreDestroy
public void destroy(){
System.out.println("销毁方法执行了");
}
public void saveAccount(){
accountDao.saveAccount();
}
}