spring

new对象的事情交给了ioc容器 发射拿到对象

   <bean id="accountService" class="com.xz.service.impl.AccountServiceImpl"
         scope=""  init-method="" destroy-method="">
       <property name=""  value="" | ref=""></property>
   </bean>
<!--把对象的创建交给spring来管理-->
-spring对bean的管理细节
    1.创建bean的三种方式
    2.bean对象的作用范围
    3.bean对象的生命周期


<!--创建Bean的三种方式 -->
 第一种方式:使用默认构造函数创建。
        在spring的配置文件中使用bean标签,配以id和class属性之后,且没有其他属性和标签时。
        采用的就是默认构造函数创建bean对象,此时如果类中没有默认构造函数,则对象无法创建。

<bean id="accountService" class="com.xz.service.impl.AccountServiceImpl"></bean>


 第二种方式: 使用普通工厂中的方法创建对象(使用某个类中的方法创建对象,并存入spring容器)
<bean id="instanceFactory" class="com.xz.factory.InstanceFactory"></bean>
<bean id="accountService" factory-bean="instanceFactory" factory-method="getAccountService"></bean>
public class InstanceFactory {

    public AccountService getAccountService(){
        return new AccountServiceImpl();
    }
}
第三种方式:使用工厂中的静态方法创建对象(使用某个类中的静态方法创建对象,并存入spring容器)
<bean id="accountService" class="com.itheima.factory.StaticFactory" factory-method="getAccountService"></bean>
  public class StaticFactory {

    public static AccountService getAccountService(){

        return new AccountServiceImpl();
    }
}
 bean的作用范围调整
    bean标签的scope属性:
        作用:用于指定bean的作用范围
        取值: 常用的就是单例的和多例的
            singleton:单例的(默认值)
            prototype:多例的
            request:作用于web应用的请求范围
            session:作用于web应用的会话范围
            global-session:作用于集群环境的会话范围(全局会话范围),当不是集群环境时,它就是session

<bean id="accountService" class="com.xz.service.impl.AccountServiceImpl" scope="prototype"></bean>


 bean对象的生命周期
        单例对象
            出生:当容器创建时对象出生
            活着:只要容器还在,对象一直活着
            死亡:容器销毁,对象消亡
            总结:单例对象的生命周期和容器相同
        多例对象
            出生:当我们使用对象时spring框架为我们创建
            活着:对象只要是在使用过程中就一直活着。
            死亡:当对象长时间不用,且没有别的对象引用时,由Java的垃圾回收器回收
 
     spring中的依赖注入
    依赖注入:
        Dependency Injection
    IOC的作用:
        降低程序间的耦合(依赖关系)
    依赖关系的管理:
        以后都交给spring来维护
    在当前类需要用到其他类的对象,由spring为我们提供,我们只需要在配置文件中说明
    依赖关系的维护:
        就称之为依赖注入。
     依赖注入:
        能注入的数据:有三类
            基本类型和String
            其他bean类型(在配置文件中或者注解配置过的bean)
            复杂类型/集合类型
         注入的方式:有三种
            第一种:使用构造函数提供
            第二种:使用set方法提供
            第三种:使用注解提供
 


构造函数注入:
    使用的标签:constructor-arg
    标签出现的位置:bean标签的内部
    标签中的属性
        type:用于指定要注入的数据的数据类型,该数据类型也是构造函数中某个或某些参数的类型
        index:用于指定要注入的数据给构造函数中指定索引位置的参数赋值。索引的位置是从0开始
        name:用于指定给构造函数中指定名称的参数赋值                                        常用的
        =============以上三个用于指定给构造函数中哪个参数赋值===============================
        value:用于提供基本类型和String类型的数据
        ref:用于指定其他的bean类型数据。它指的就是在spring的Ioc核心容器中出现过的bean对象

    优势:
        在获取bean对象时,注入数据是必须的操作,否则对象无法创建成功。
    弊端:
        改变了bean对象的实例化方式,使我们在创建对象时,如果用不到这些数据,也必须提供。
 *用于创建对象的
   他们的作用就和在XML配置文件中编写一个<bean>标签实现的功能是一样的
  • Component:
    作用:用于把当前类对象存入spring容器中
    属性:
    value:用于指定bean的id。当我们不写时,它的默认值是当前类名,且首字母改小写。
  •  Controller:一般用在表现层 
    
  •  Service:一般用在业务层 
    
  •  Repository:一般用在持久层
    
    以上三个注解他们的作用和属性与Component是一模一样。
    他们三个是spring框架为我们提供明确的三层使用的注解,使我们的三层对象更加清晰

用于注入数据的
他们的作用就和在xml配置文件中的bean标签中写一个标签的作用是一样的

Autowired:
作用:自动按照类型注入。只要容器中有唯一的一个bean对象类型和要注入的变量类型匹配,就可以注入成功
如果ioc容器中没有任何bean的类型和要注入的变量类型匹配,则报错。 *
如果Ioc容器中有多个类型匹配时:
出现位置:
可以是变量上,也可以是方法上
细节:
在使用注解注入时,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-methode的作用是一样的 *
PreDestroy *
作用:用于指定销毁方法 *
PostConstruct *
作用:用于指定初始化方法

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值