IOC容器--Bean管理--基于注解方式

1. 基于注解方式创建对象

什么是注解

​ (1)注解是代码特殊标记,格式:@注解名称(属性名称=属性值, 属性名称=属性值…)
​ (2)使用注解,注解作用在类上面,方法上面,属性上面
​ (3)使用注解目的:简化 xml 配置

Spring 针对 Bean 管理中创建对象提供注解

​ 下面四个注解功能是一样的,都可以用来创建 bean 实例
​ (1)@Component
​ (2)@Service
​ (3)@Controller
​ (4)@Repository

第一步 引入依赖 (引入spring-aop jar包)

spring-aop-5.2.6.RELEASE.jar

第二步 开启组件扫描

Spring配置文件中:

<!--开启组件扫描
 1 如果扫描多个包,多个包使用逗号隔开
 2 扫描包上层目录
-->
<context:component-scan base-package="com.atguigu"></context:component-scan>

第三步 创建类,在类上面添加创建对象注解

创建UserService

//在注解里面 value 属性值可以省略不写,
//默认值是类名称,首字母小写
//UserService -- userService
@Component(value = "userService") //注解等同于XML配置文件:<bean id="userService" class=".."/>
public class UserService {
    
    
 public void add() {
    
    
 System.out.println("service add.......");
 }
}

第四步 测试代码

public class TestSpringDemo {
    
    
    public static void main(String[] args) {
    
    
        // 加载配置文件
        ApplicationContext context =
                new ClassPathXmlApplicationContext("bean1.xml");
        UserService userService = context.getBean("userService",UserService.class);
        userService.add();
        System.out.println(userService);

    }
}

2.组件扫描配置

Spring配置文件中:

<!--示例 1
 use-default-filters="false" 表示现在不使用默认 filter,自己配置 filter
 context:include-filter ,设置扫描哪些内容
-->

<context:component-scan base-package="com.atguigu" use-defaultfilters="false">
 <context:include-filter type="annotation"
			expression="org.springframework.stereotype.Controller"/><!--代表只扫描Controller注解的类-->
</context:component-scan>


<!--示例 2
 下面配置扫描包所有内容
 context:exclude-filter: 设置哪些内容不进行扫描
-->
<context:component-scan base-package="com.atguigu">
 <context:exclude-filter type="annotation"
 			expression="org.springframework.stereotype.Controller"/><!--表示Controller注解的类之外一切都进行扫描-->
</context:component-scan>

3.基于注解方式实现属性注入

@Autowired
@Qualifier
@Resource
@Value
(1)@Autowired:根据属性类型进行自动装配
​第一步 把 service 和 dao 对象创建,在 service 和 dao 类添加创建对象注解
第二步 在 service 注入 dao 对象,在 service 类添加 dao 类型属性,在属性上面使用注解

dao类代码如下:

//Dao实现类
@Repository
//@Repository(value = "userDaoImpl1")
public class UserDaoImpl implements UserDao {
    
    
    @Override
    public void add() {
    
    
        System.out.println("dao add.....");
    }
}

UserService类代码如下:

@Service
public class UserService {
    
    
 //定义 dao 类型属性
 //不需要添加 set 方法
 //添加注入属性注解
 @Autowired
 private UserDao userDao;
 public void add() {
    
    
 System.out.println("service add.......");
 userDao.add();
 }
}

(2)@Qualifier:根据名称进行注入,这个@Qualifier 注解的使用,和上面@Autowired 一起使用

在UserService类中,配合@Autowired使用:

//定义 dao 类型属性
//不需要添加 set 方法
//添加注入属性注解
@Autowired //根据类型进行注入
//根据名称进行注入(目的在于区别同一接口下有多个实现类,根据类型就无法选择,从而出错!)
@Qualifier(value = "userDaoImpl1") 
private UserDao userDao;

(3)@Resource:可以根据类型注入,也可以根据名称注入(它属于javax包下的注解,不推荐使用!)

//@Resource //根据类型进行注入
@Resource(name = "userDaoImpl1") //根据名称进行注入
private UserDao userDao;

(4)@Value:注入普通类型属性

@Value(value = "abc")
private String name

4.完全注解开发

(1)创建配置类,替代 xml 配置文件

@Configuration //作为配置类,替代 xml 配置文件
@ComponentScan(basePackages = {
    
    "com.atguigu"})
public class SpringConfig {
    
      
}

(2)编写测试类

@Test
public void testService2() {
    
    
 //加载配置类
 ApplicationContext context
 = new AnnotationConfigApplicationContext(SpringConfig.class);
 UserService userService = context.getBean("userService",
UserService.class);
 System.out.println(userService);
 userService.add();
}

猜你喜欢

转载自blog.csdn.net/Kc635908933/article/details/111369512