spring对bean的管理细节和依赖注入(基于注解和xml)

F:\spring\day02_eesy_01anno_ioc

用于其他bean类型的数据的注入:
Autowired: 自动
直接安装类名在spring的ioc容器中查找
如果类不唯一
会根据类名找匹配的,如果没有匹配就会报错

Qualifier:得和Autowired配合使用,相当于在自动的情况下,确认类名

@Autowired
@Qualifier(“accountDao1”)

等同于
@Resource(name = “accountDao1”)

用于注入基本类型和StringV类型的数据:
@Value

用于改变作用范围的:
@Scope

 *  用于改变作用范围的
 *      他们的作用就和在bean标签中使用scope属性使用的功能是一样的
 *      Scope:
 *          作用:用于指定bean的作用范围
 *          属性:
 *              value:指定范围的取值。常用取值:singleton prototype
 *
 *  和生命周期相关的 (了解)
 *      他们的作用就和在bean标签中使用init-method和destroy-method的作用是一样的
 *      PrieDestroy:
 *          作用:用于指定销毁方法
 *      PostConstruct:
 *          作用:用于指定初始化方法

AccountServiceImpl.java

package com.itheima.service.impl;

import com.itheima.dao.IAccountDao;
import com.itheima.dao.impl.AccountDaoImpl;
//import com.itheima.factory.BeanFactory;
import com.itheima.service.IAccountService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.context.annotation.Scope;
import org.springframework.stereotype.Component;
import org.springframework.stereotype.Service;

import javax.annotation.PostConstruct;
import javax.annotation.PreDestroy;
import javax.annotation.Resource;

/**
 * 账户业务层实现类
 *
 * 曾经XML的配置:
 * <bean id="accountDao" class="com.itheima.dao.impl.AccountDaoImpl"
 *       scope="" init-method="" destroy-method="">
 *       <property name="" value="" | ref=""></property>
 * </bean>
 *
 *  用于创建对象的
 *      他们的作用就和在XML配置文件中编写一个<bean>标签实现的功能时一样的
 *      Component:
 *          作用:用于把当前类对象存入spring容器中
 *          属性:
 *              value:用于指定bean的id,当我们不写时,默认值为当前类名,写首字母改小写
 *      Controller:一般用在表现层
 *      Service:一般用在业务层
 *      Repository:一般用在持久层
 *      以上三个注解他们的作用和属性与Component是一模一样的。
 *      他们三个是spring框架为我们提供明确的三层使用的注解,使我们的三层对象更加清晰
 *  用于注入数据的
 *      他们的作用就和在xml配置文件中的bean标签中写一个<property>标签的作用时一样的
 *      Autowired:
 *          作用:自动按照类型注入,只要容器中有唯一的一个bean对象类型和要注入的变量类型匹配,就可以注入成功
 *              如果ioc容器中没有任何bean的类型和要注入的变量类型匹配,则报错。
 *          出现位置:
 *              可以是变量上,也可以是方法上
 *          细节:
 *              在使用注解注入时,set方法就不是必须的了。
 *      Qualifier:
 *          作用:在按照类中注入的基础之上在按照名称注入,它在给类成员注入时不能单独使用,但是在给方法参数注入时可以
 *          属性:
 *              value:用于指定注入bean的id
 *      Resource:
 *          作用:直接按照bean的id注入,它可以独立使用
 *          属性:
 *              name:用于指定bean的id
 *      以上三个注解都只能注入其他bean类型的数据,而基本类型和String类型无法使用上述注解实现
 *      另外,集合类型的注入只能通过XML来实现。
 *
 *      Value:
 *          作用:用于注入基本类型和String类型的数据
 *          属性:
 *              value:用于指定数据的值,它可以使用spring中的SpEl(spring中的el表达式)
 *                      SpEl的写法:${表达式}
 *  用于改变作用范围的
 *      他们的作用就和在bean标签中使用scope属性使用的功能是一样的
 *      Scope:
 *          作用:用于指定bean的作用范围
 *          属性:
 *              value:指定范围的取值。常用取值:singleton prototype
 *
 *  和生命周期相关的 (了解)
 *      他们的作用就和在bean标签中使用init-method和destroy-method的作用是一样的
 *      PrieDestroy:
 *          作用:用于指定销毁方法
 *      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();
    }
}

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>

Client.java

package com.itheima.ui;

import com.itheima.dao.IAccountDao;
//import com.itheima.factory.BeanFactory;
import com.itheima.service.IAccountService;
import com.itheima.service.impl.AccountServiceImpl;
import javafx.application.Application;
import org.springframework.beans.factory.BeanFactory;
import org.springframework.beans.factory.xml.XmlBeanFactory;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.springframework.context.support.FileSystemXmlApplicationContext;
import org.springframework.core.io.ClassPathResource;
import org.springframework.core.io.Resource;

/**
 * 模拟一个表现出,用于调用业务层
 */
public class Client {

    /**
     * @param args
     */
    public static void main(String[] args) {
        //1.获取核心容器对象
        ApplicationContext ac = new ClassPathXmlApplicationContext("bean.xml");
        //2.根据id获取Bean对象
        IAccountService as = (IAccountService) ac.getBean("accountService");
//        IAccountService as2 = (IAccountService) ac.getBean("accountService");

//        System.out.println(as);
//        IAccountDao adao = ac.getBean("accountDao",IAccountDao.class);
//        System.out.println(adao);
//        System.out.println(as == as2);
        as.saveAccount();
        ((ClassPathXmlApplicationContext) ac).close();


    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值