spring的第二天

ssm框架 spring 

在昨天简单的介绍了一下spring,那么今天接着继续介绍。

  • spring值的注入
  • 自动装配【autowire】
  • 引用资源
  • applicationContext和beanFactory的关系

spring的值的注入

在spring的第一天里面我介绍了spring基本类型值的注入以及引用类型值的注入,那么这次我们讨论数组listmap值的注入问题

首先有一个Person类

package com.weno.bean;

public class Person {

    private String name;
private int 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 "Person{" +
"name='" + name + '\'' +
", age=" + age +
'}';
}
}

然后有一个Persons的类

package com.weno.bean;
import java.util.List;
public class Persons { private List<Person> personList; public List<Person> getPersonList() {
return personList;
} public void setPersonList(List<Person> personList) {
this.personList = personList;
} @Override
public String toString() {
return "Persons{" +
"personList=" + personList +
'}';
}
}
  • lsit

    在xml文件中

    <bean id="persons" class="com.weno.bean.Persons">
    <property name="personList">
    <list>
    <!-- 使用外部bean则为<ref bean="***"/>-->
    <bean class="com.weno.bean.Person">
    <property name="name" value="张三"/>
    <property name="age" value="14"/>
    </bean>
    <bean class="com.weno.bean.Person">
    <property name="name" value="李四"/>
    <property name="age" value="18"/>
    </bean>
    </list>
    </property>
    </bean>
  • 数组

    注入数组元素和注入list元素是一样的,都是使用<list>标签,就不介绍了。

  • set

        <bean id="persons" class="com.weno.bean.Persons">
    <property name="personSet">
    <set>
    <bean class="com.weno.bean.Person">
    <property name="name" value="张三"/>
    <property name="age" value="14"/>
    </bean>
    <bean class="com.weno.bean.Person">
    <property name="name" value="李四"/>
    <property name="age" value="18"/>
    </bean>
    </set>
    </property>
    </bean>

    然后有个好神奇的现象,将<set> 标签换成<list>竟然也可以完美运行。

  • map

    <bean class="com.weno.bean.Persons" id="persons">
    <property name="map">
    <map>
    <!-- 使用外部bean <entry key="person1" value-ref="***"/> -->
    <entry key="person1">
    <bean class="com.weno.bean.Person">
    <property name="name" value="张三"/>
    <property name="age" value="14"/>
    </bean>
    </entry>
    <entry key="person2">
    <bean class="com.weno.bean.Person">
    <property name="name" value="李四"/>
    <property name="age" value="17"/>
    </bean>
    </entry>
    </map>
    </property>
    </bean>

    当然,在这集中集合中,我们既可以引用基本类型,也可以使用引用类型,在使用引用类型中,我们既可以使用外部bean的方式去使用,也可以使用内部Bean的方式去引用。

自动装配

spring的自动装配的默认值为no,也就是不进行自动装配

spring的自动装配分为:

  • byType 按照数据类型注入
  • byName 按照pojo对应的属性名字进行匹配
  • byConstruct
    • 优先按照类型进行注入,如果匹配到一个,就直接注入,如果不止一个,就按照名字注入,如果一个都找不到,则注入失败。
  • default(默认值)

如果在上面的Person类里面再加上了一个Teacher。

定义Teacher的类:

public class Teacher {
private String name; public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} @Override
public String toString() {
return "Teacher{" +
"name='" + name + '\'' +
'}';
}
  • byName

    <bean id="person" class="com.weno.bean.Person" autowire="byName">
    <!-- 通过名字自动装配 -->
    <property name="name" value="王五"/>
    <property name="age" value="18"/>
    </bean> <bean id="teacher" class="com.weno.bean.Teacher">
    <property name="name" value="老师"/>
    </bean>

    如果这时候将结果进行输出会怎样?

    Person{name='王五', age=18, teacher=Teacher{name='老师'}}

    在这里自动的将treacher装配进来了。这个是根据名字进行自动加载的,接下来看看byType.

  • byType

    <bean id="person" class="com.weno.bean.Person" autowire="byType">
    <!-- 通过类型进行导入 -->
    <property name="name" value="王五"/>
    <property name="age" value="18"/>
    </bean> <bean id="teacher1" class="com.weno.bean.Teacher">
    <property name="name" value="老师"/>
    </bean>

    Question:

    1. 那么byTypebyName有什么区别呢?
      byType对于名字没有要求,在上面的代码中,即使id为teacher1,也可以成功导入,而byName却不行。
    2. 如果有多个相同类型的bean会怎么导入,怎么控制导入?
      如果有多个相同的bean,byType导入会报错。

      Unsatisfied dependency expressed through bean property 'teacher': No qualifying bean of type [com.weno.bean.Teacher] is defined: expected single matching bean but found 2:

      解决方法,使用primary设置优先级即可,将其中一个设置为主bean。

      <bean id="teacher1" class="com.weno.bean.Teacher" primary="true">
      <!-- primary默认是false,但是好像在某些版本默认是false -->
      <property name="name" value="大老师"/>
      </bean>
      <bean id="Teacher" class="com.weno.bean.Teacher">
      <property name="name" value="小老师"/>
      </bean>

      这时候就可以看到结果了

      Person{name='王五', age=18, teacher=Teacher{name='大老师'}}
  • byConstruct

    与byType的方式类似,不同之处在于它应用于构造器参数。优先按照类型进行注入,如果匹配到一个,就直接注入,如果不止一个,就按照名字注入,如果一个都找不到,则注入失败。

    在person类中加入构造方法

    public Person(Teacher teacher) {
    this.teacher = teacher;
    } // 注意,这个也要保留
    public Person() {
    }
    <bean id="person" class="com.weno.bean.Person" autowire="constructor">
    <property name="name" value="王五"/>
    <property name="age" value="18"/>
    </bean> <bean id="teacher" class="com.weno.bean.Teacher">
    <property name="name" value="大老师"/>
    </bean> <bean id="teacher2" class="com.weno.bean.Teacher">
    <property name="name" value="小老师"/>
    </bean>

    在这两个中,按照第一个会装配,而第二个不会装配。【ps:当匹配到多个时,优先按照名字装配,如ru果有多个,名字又不匹配,就报错】

引入资源

  • 引入其他xml文件
    试想一下,如果我们将所有的配置全部写在一个文件中,那么该多么庞杂,且不利于项目合作,这时候我们就可以使用一个主文件,目的是来导入其他文件。

    <!--导入其他-->
    <import resource="classpath:personConfig.xml"/>

    如果我们需要导入很多xml文件怎么办,这时候我们可以使用通配符*来导入
    假如在一个manager.xml文件中引入资源spring-person,spring-test,这时,我们可以这样做:

    <!-- 注意,使用通配符时,不要将总文件包含!
    如果在这里将manager.xml命名为spring-manager.xml,
    那么就会报错
    -->
    <import resource="spring-*.xml"/>

applicationContext和beanFactory的关系

 

 

BeanFactory是Spring容器最基本的接口,负责读取bean的配置文件,管理bean的加载和实例化。

而Application是BeanFactory的子接口,对BeanFactory进行了扩展,比如AOP,Web。

  1. 提供了支持国际化的文本消息
  2. 统一的资源文件读取方式
  3. 已在监听器中注册的bean的事件

区别:

  1. 使用BeanFactory的时候,不会预处理Bean,所以及时正确的创建了BeanFactory实例,在getBean的时候仍任可能报错抛出异常。而在applicationContext中,会默认初始化所有的Bean,所以在前期applicationContext会有较大的开销,但是获取完后却能得到较好的性能。当然也可以使用lazy-init,阻止该bean的初始化。
  2. BeanFactory需要手动注册,而ApplicationContext是自动注册的。

spring的第二天的更多相关文章

  1. Spring框架第二天

    ## Spring框架第二天 ## ---------- **课程回顾:Spring框架第一天** 1. 概述 * IOC和AOP 2. 框架的IOC的入门 * 创建applicationContex ...

  2. #Spring实战第二章学习笔记————装配Bean

    Spring实战第二章学习笔记----装配Bean 创建应用对象之间协作关系的行为通常称为装配(wiring).这也是依赖注入(DI)的本质. Spring配置的可选方案 当描述bean如何被装配时, ...

  3. Spring Cloud第二篇 | 使用并认识Eureka注册中心

    ​ 本文是Spring Cloud专栏的第二篇文章,了解前一篇文章内容有助于更好的理解本文: Spring Cloud第一篇 | Spring Cloud前言及其常用组件介绍概览 ​​ 一.Sprin ...

  4. spring实战第二章小记-装配bean

    时间:2020/02/06 一.思想 1.创建应用对象之间协作关系的行为通常称为装配,这也是依赖注入(DI)的本质. 对于上面这句话的个人理解:当我们在new一个对象时如果传入了别的对象作为参数(这个 ...

  5. 学习spring的第二天

    对昨天的查漏:关于<bean>标签的scope属性,是由它决定原型和单例的,而不是说你java代码中用到了单例模式就是单例了. 其二就是lazy-init属性,它对于scope=" ...

  6. 【Java EE 学习 50】【Spring学习第二天】【使用注解的DI实现】【spring中的继承】【动态代理伪hibernate实现】

    一.使用注解的DI实现 1.@Resource 使用该注解能够实现引用型属性的DI实现,该注解能够根据属性名和属性类型自动给属性赋值.一般使用@Resource(name="student& ...

  7. spring mvc 第二天【注解实现springmvc Handler处理ajax简单请求 的配置】

    这里使用的是在前台发起ajax请求Handler,后台伪造数据响应给前台, 配置对应ajax请求的Handler信息如下 @Controller public class MyController { ...

  8. 一起来学Spring Cloud | 第二章:服务注册和发现组件 (Eureka)

    本篇文章,很浅显的一步步讲解如何搭建一个能运行的springcloud项目(带所有操作截图).相信!看完本篇之后,你会觉得springcloud搭建如此简单~~~~ 一. Eureka简介: 1.1  ...

  9. 《玩转Spring》第二章 BeanPostProcessor扩展

    版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/shan9liang/article/details/34421141 上一章.介绍了怎样扩展spri ...

随机推荐

  1. 设置DataGridView中表头颜色

    默认的DataGridView表头颜色实在不是太好看,想设置下,上google搜了一通, 都说这样设置 this.dataGridView1.ColumnHeadersDefaultCellStyle ...

  2. 搭建django

    虚拟环境配置 pip install virtualenv 一般需要安装一个管理工具:pip install virtualenvwrapper-win 只有它可以使用workon 创建虚拟环境:mk ...

  3. js--获得当前系统时间

    window.onload = function () { var oBody = document.body; setInterval( fnTime, 1000 ); fnTime (); fun ...

  4. javascript常见内存泄露

    一.全局变量引起的内存泄漏 function func(){ lmw = 123456 //lmw是全局变量,不会被释放 } 二.闭包引起的内存泄漏 function func(){ var lmw ...

  5. ABP框架系列之四十三:(OData-Integration-OData集成)

    Introduction OData is defined as "An open protocol to allow the creation and consumption of que ...

  6. Spring AOP中pointcut expression表达式

    Pointcut 是指那些方法需要被执行"AOP",是由"Pointcut Expression"来描述的. Pointcut可以有下列方式来定义或者通过&am ...

  7. tarjan求强连通分量+缩点+割点/割桥(点双/边双)以及一些证明

    “tarjan陪伴强联通分量 生成树完成后思路才闪光 欧拉跑过的七桥古塘 让你 心驰神往”----<膜你抄>   自从听完这首歌,我就对tarjan开始心驰神往了,不过由于之前水平不足,一 ...

  8. git cmd 命令在已有的仓库重新添加新的文件夹

    正确步骤: 1. git init //初始化仓库 git add .(文件name) //添加文件到本地仓库 git commit -m “first commit” //添加文件描述信息 git ...

  9. 网络编程—端口分类调研和netstat命令

    运输层的端口: 1.什么是端口?为甚要使用用端口? 进程的创建和撤销都是动态的,通信的一方几乎无法识别对方机器上的进程,我们需要利用目的主机提供的功能来识别终点. 所以为了解决上述问题,我们就在运输层 ...

  10. CPU Hardwar

    GPU负责把线程块分配到各个SM上处理. CUDA对申请的线程块何时运行,以及在哪个SM上运行是没有保证的.这恰好是GPU的优势,这种方式带来了灵活性,不需程序根据SM的数量去配置程序. 但是一个bl ...