依 赖 注 入(2)【重点】

本文介绍了Spring中的依赖注入,包括P命名空间和C命名空间的注入方式,以及Bean的两种主要作用域:单例和原型。详细阐述了不同作用域在不同场景下的应用,如单例模式适用于无状态的bean,原型模式适用于有状态的bean,并提供了XML配置示例。
摘要由CSDN通过智能技术生成

拓展方式注入

1、P命名和C命名注入

        我们可以使用p命令空间和c命令空间进行注入

官方解释:

 

User.java

package com.gt.pojo;

public class User {
    private String name;
    private int age;

    //    无参构造
    public User() {
    }

    //    有参构造器
    public User(String name, int age) {
        this.name = name;
        this.age = age;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    @Override
    public String toString() {
        return "User{" +
                "name='" + name + '\'' +
                ", age=" + age +
                '}';
    }
}

 注意点:

        p命名和c命名空间不能直接使用,需要导入xml约束!

  • P命名

    bean的作用域(Bean scopes)

    注入:需要在头文件中加入约束文件

xmlns:p="http://www.springframework.org/schema/p"
  • C命名注入:需要在头文件中加入约束文件

xmlns:c="http://www.springframework.org/schema/c"
<?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:p="http://www.springframework.org/schema/p"
       xmlns:c="http://www.springframework.org/schema/c"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
        https://www.springframework.org/schema/beans/spring-beans.xsd">

    <!--p命名空间注入,可以直接注入属性的值:property-->
    <bean id="user" class="com.gt.pojo.User" p:name="山姆" p:age="18"/>

    <!--c命名空间注入,通过构造器注入:construct-args-->
    <bean id="user2" class="com.gt.pojo.User" c:age="18" c:name="闪闪" scope="prototype"/>
<!--
scope="singleton" 单例模式 输出的结果是相等的(spring默认机制)
scope="prototype" 原型模式 输出的结果是不相等的
-->

</beans>

 

p命名注入:

<?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:p="http://www.springframework.org/schema/p"
       xmlns:c="http://www.springframework.org/schema/c"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
        https://www.springframework.org/schema/beans/spring-beans.xsd">

    <!--p命名空间注入,可以直接注入属性的值:property-->
    <bean id="user" class="com.gt.pojo.User" p:name="山姆" p:age="18"/>


</beans>

输出结果: 

 

c命名注入:

  • scope="singleton" 单例模式 输出的结果是相等的(spring默认机制)
  • scope="prototype" 原型模式 输出的结果是不相等的 
<?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:p="http://www.springframework.org/schema/p"
       xmlns:c="http://www.springframework.org/schema/c"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
        https://www.springframework.org/schema/beans/spring-beans.xsd">


    <!--c命名空间注入,通过构造器注入:construct-args-->
    <bean id="user2" class="com.gt.pojo.User" c:age="18" c:name="闪闪" scope="prototype"/>
<!--
scope="singleton" 单例模式 输出的结果是相等的(spring默认机制)
scope="prototype" 原型模式 输出的结果是不相等的
-->

</beans>

输出结果:

 

 测试:

    @Test
    public void test2(){
        ApplicationContext context = new ClassPathXmlApplicationContext("userbeans.xml");
        User user = (User) context.getBean("user2");
        User user2 = (User) context.getBean("user2");
        System.out.println(user==user2);
    }

 

bean的作用域(Bean scopes)

 

(1)单例模式(Spring默认机制)

        当一个bean的作用域为Singleton,那么Spring IoC容器中只会存在一个共享的bean实例,并且所有对bean的请求,只要id与该bean定义相匹配,则只会返回bean的同一实例。Singleton是单例类型,就是在创建起容器时就同时自动创建了一个bean的对象,不管你是否使用,他都存在了,每次获取到的对象都是同一个对象。注意,Singleton作用域是Spring中的缺省作用域。要在XML中将bean定义成singleton,可以这样配置:

  <!--c命名空间注入,通过构造器注入:construct-args-->
    <bean id="user2" class="com.gt.pojo.User" c:age="18" c:name="闪闪" scope="singleton"/>

 

测试:  

    @Test
    public void test2(){
        ApplicationContext context = new ClassPathXmlApplicationContext("userbeans.xml");
        User user = (User) context.getBean("user2");
        User user2 = (User) context.getBean("user2");
        System.out.println(user==user2);
    }

输出结果: 

 

(2)原型模式

每次从容器中get的时候,都会产生一个新对象。

        当一个bean的作用域为Prototype,表示一个bean定义对应多个对象实例。Prototype作用域的bean会导致在每次对该bean请求(将其注入到另一个bean中,或者以程序的方式调用容器的getBean()方法)时都会创建一个新的bean实例。Prototype是原型类型,它在我们创建容器的时候并没有实例化,而是当我们获取bean的时候才会去创建一个对象而且我们每次获取到的对象都不是同一个对象。根据经验,对有状态的bean应该使用prototype作用域,而对无状态的bean则应该使用singleton作用域。在XML中将bean定义成prototype,可以这样配置:

  <!--c命名空间注入,通过构造器注入:construct-args-->
    <bean id="user2" class="com.gt.pojo.User" c:age="18" c:name="闪闪" scope="prototype"/>

测试: 

    @Test
    public void test2(){
        ApplicationContext context = new ClassPathXmlApplicationContext("userbeans.xml");
        User user = (User) context.getBean("user2");
        User user2 = (User) context.getBean("user2");
        System.out.println(user==user2);
    }

输出结果:

 

 扩展(要在web中才能使用)

        其余的request、session、application这些个只能再web开发中使用到!

(1)request

        当一个bean的作用域为Request,表示在一次HTTP请求中,一个bean定义对应一个实例;即每个HTTP请求都会有各自的bean实例,它们依据某个bean定义创建而成。该作用域仅在基于web的Spring ApplicationContext情形下有效。考虑下面bean定义:

  <bean id="loginAction" class=cn.csdn.LoginAction" scope="request"/>

        针对每次HTTP请求,Spring容器会根据loginAction bean的定义创建一个全新的LoginAction bean实例,且该loginAction bean实例仅在当前HTTP request内有效,因此可以根据需要放心的更改所建实例的内部状态。而其他请求中根据loginAction bean定义创建的实例,将不会看到这些特定于某个请求的状态变化。当处理请求结束,request作用域的bean实例将被销毁。

(2)session

        当一个bean的作用域为Session,表示在一个HTTP Session中,一个bean定义对应一个实例。该作用域仅在基于web的Spring ApplicationContext情形下有效。考虑下面bean定义:

 <bean id="userPreferences" class="com.foo.UserPreferences" scope="session"/>

        针对某个HTTP Session,Spring容器会根据userPreferences bean定义创建一个全新的userPreferences bean实例,且该userPreferences bean仅在当前HTTP Session内有效。与request作用域一样,可以根据需要放心的更改所创建实例的内部状态,而别的HTTP Session中根据userPreferences创建的实例,将不会看到这些特定于某个HTTP Session的状态变化。当HTTP Session最终被废弃的时候,在该HTTP Session作用域内的bean也会被废弃掉。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值