Spring从入门到源码之IOC基本用法

1、spring_helloworld

使用maven的方式来构建项目(Mavaen)

添加对应的pom依赖
pom.xml

<dependencies>
        <!-- https://mvnrepository.com/artifact/org.springframework/spring-context -->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</artifactId>
            <version>5.2.3.RELEASE</version>
        </dependency>
    </dependencies>

编写代码
Person.java

 public class Person {
      private int id;
      private String name;
      private int age;
      private String gender;

      public int getId() {
          return id;
      }
      public void setId(int id) {
          this.id = id;
      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;
      public String getGender() {
          return gender;
      public void setGender(String gender) {
          this.gender = gender;
      @Override
      public String toString() {
          return "Person{" +
                  "id=" + id +
                  ", name='" + name + '\'' +
                  ", age=" + age +
                  ", gender='" + gender + '\'' +
                  '}';
  }

测试

MyTest.java

public class MyTest {
    public static void main(String[] args) {
        ApplicationContext context = new ClassPathXmlApplicationContext("ioc.xml");
        Person person = (Person) context.getBean("person");
        System.out.println(person);
    }
 }

总结:

一定要将配置文件添加到类路径中,使用idea创建项目的时候要放在resource目录下创建对象给属性赋值的时候是通过setter方法实现的对象在IOC容器中存储的时候都是单例的,如果需要多例需要修改属性(默认单例,可以改多例)对象在Spring容器创建完成的时候就已经创建完成,不是需要用的时候才创建(Application创建时候对象就创建了)ApplicationContext就是IOC容器的接口,可以通过此对象获取容器中创建的对象

2、spring对象的获取及属性赋值方式

1、通过bean的id获取IOC容器中的对象(上面已经用过)

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
<!--
    id 对象唯一标识
    class 类名字:完全限定名字
-->
   <bean id = "person" class="com.yao.bean.Person">
       <property name="id" value="001"/>
       <property name="name" value="yzh"/>
       <property name="age" value="12"/>
       <property name="gender" value="man"/>
   </bean>

</beans>
  • 一定要将配置文件添加到类路径中,使用idea创建项目的时候要放在resource目录下
  • 创建对象给属性赋值的时候是通过setter方法实现的
  • 对象在IOC容器中存储的时候都是单例的,如果需要多例需要修改属性(默认单例,可以改多例)
  • 对象在Spring容器创建完成的时候就已经创建完成,不是需要用的时候才创建(Application创建时候对象就创建了)
  • ApplicationContext就是IOC容器的接口,可以通过此对象获取容器中创建的对象

2、通过bean的类型获取对象

ApplicationContext context = new ClassPathXmlApplicationContext("ioc.xml");
        Person bean = context.getBean(Person.class);
        System.out.println(bean);

注意:通过bean的类型在查找对象的时候,在配置文件中不能存在两个类型一致的bean对象,如果有的话,可以通过如下方法

  public class MyTest {
        public static void main(String[] args) {
            ApplicationContext context = new ClassPathXmlApplicationContext("ioc.xml");
            Person person = context.getBean("person", Person.class);
            System.out.println(person);
        }
    }

3、通过构造器给bean对象赋值

总结:

  • constructor-arg 给person类添加构造方法
  • 使用构造器赋值的时候可以省略name属性,但是此时就要求必须严格按照构造器参数的顺序来填写了
  • 如果想不按照顺序来添加参数值,那么可以搭配index属性来使用
  • 当有多个参数个数相同,不同类型的构造器的时候,可以通过type来强制类型
  • 两个重载的构造方法,后面的构造方法覆盖前面的构造方法。
constructor-arg中五个属性值:
value:赋值
name:成员属性
ref :通过ref引用其他对象,引用外部bean
index:如果想不按照顺序来添加参数值,那么可以搭配index属性来使用
type:当有多个参数个数相同,不同类型的构造器的时候,可以通过type来强制类型

ioc.xml

<!--给person类添加构造方法-->
	<bean id="person2" class="com.mashibing.bean.Person">
        <constructor-arg name="id" value="1"></constructor-arg>
        <constructor-arg name="name" value="lisi"></constructor-arg>
        <constructor-arg name="age" value="20"></constructor-arg>
        <constructor-arg name="gender" value="女"></constructor-arg>
        </bean>

	<!--在使用构造器赋值的时候可以省略name属性,但是此时就要求必须严格按照构造器参数的顺序来填写了-->
	<bean id="person3" class="com.mashibing.bean.Person">
        <constructor-arg value="1"></constructor-arg>
        <constructor-arg value="lisi"></constructor-arg>
        <constructor-arg value="20"></constructor-arg>
        <constructor-arg value="女"></constructor-arg>
        </bean>

	<!--如果想不按照顺序来添加参数值,那么可以搭配index属性来使用-->
      <bean id="person4" class="com.mashibing.bean.Person">
          <constructor-arg value="lisi" index="1"></constructor-arg>
          <constructor-arg value="1" index="0"></constructor-arg>
          <constructor-arg value="女" index="3"></constructor-arg>
          <constructor-arg value="20" index="2"></constructor-arg>
      </bean>
	<!--当有多个参数个数相同,不同类型的构造器的时候,可以通过type来强制类型-->
	将person的age类型设置为Integer类型
	public Person(int id, String name, Integer age) {
        this.id = id;
        this.name = name;
        this.age = age;
        System.out.println("Age");
    }
	// 后面的构造方法覆盖前面的构造方法。
    public Person(int id, String name, String gender) {
        this.id = id;
        this.name = name;
        this.gender = gender;
        System.out.println("gender");
    }
	<bean id="person5" class="com.mashibing.bean.Person">
        <constructor-arg value="1"></constructor-arg>
        <constructor-arg value="lisi"></constructor-arg>
        <constructor-arg value="20" type="java.lang.Integer"></constructor-arg>
    </bean>
	<!--如果不修改为integer类型,那么需要type跟index组合使用-->
	 <bean id="person5" class="com.mashibing.bean.Person">
        <constructor-arg value="1"></constructor-arg>
        <constructor-arg value="lisi"></constructor-arg>
        <constructor-arg value="20" type="int" index="2"></constructor-arg>
    </bean>

4、通过命名空间为bean赋值,简化配置文件中属性声明的写法

p导入命名空间,还有c命名空间,更简单的命名方式,仅此而已。、
1、导入命名空间--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:p="http://www.springframework.org/schema/p"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">

2、添加配置ioc.xml

 <bean id="person6" class="com.mashibing.bean.Person" p:id="3" p:name="wangwu" p:age="22" p:gender="男"></bean>

5、为复杂类型进行赋值操作(重点)

总结:

给各种复杂类型赋值,如集合、数组、其他对象等。
创建类如下:Person.java 、 Book.java、 Address.java 作为演示

Person.java

import java.util.*;
public class Person {
    private int id;
    private String name="dahuang";
    private int age;
    private String gender;
    private Address address;
    private String[] hobbies;
    private List<Book> books;
    private Set<Integer> sets;
    private Map<String,Object> maps;
    private Properties properties; // 没用过这个数据类型
    public Person(int id, String name, int age, String gender) {
        this.id = id;
        this.name = name;
        this.age = age;
        this.gender = gender;
        System.out.println("有参构造器");
    }
    public Person(int id, String name, int age) {
        this.id = id;
        this.name = name;
        this.age = age;
        System.out.println("Age");
    }
    public Person(int id, String name, String gender) {
        this.id = id;
        this.name = name;
        this.gender = gender;
        System.out.println("gender");
    }
    public Person() {
    }
    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    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;
    }
    public String getGender() {
        return gender;
    }
    public void setGender(String gender) {
        this.gender = gender;
    }
    public Address getAddress() {
        return address;
    }
    public void setAddress(Address address) {
        this.address = address;
    }
    public List<Book> getBooks() {
        return books;
    }
    public void setBooks(List<Book> books) {
        this.books = books;
    }
    public Map<String, Object> getMaps() {
        return maps;
    }
    public void setMaps(Map<String, Object> maps) {
        this.maps = maps;
    }
    public Properties getProperties() {
        return properties;
    }
    public void setProperties(Properties properties) {
        this.properties = properties;
    }
    public String[] getHobbies() {
        return hobbies;
    }
    public void setHobbies(String[] hobbies) {
        this.hobbies = hobbies;
    }
    public Set<Integer> getSets() {
        return sets;
    }
    public void setSets(Set<Integer> sets) {
        this.sets = sets;
    }
    @Override
    public String toString() {
        return "Person{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", age=" + age +
                ", gender='" + gender + '\'' +
                ", address=" + address +
                ", hobbies=" + Arrays.toString(hobbies) +
                ", books=" + books +
                ", sets=" + sets +
                ", maps=" + maps +
                ", properties=" + properties +
                '}';
    }
}

Book.java

public class Book {
    private String name;
    private String author;
    private double price;
    public Book() {
    }
    public Book(String name, String author, double price) {
        this.name = name;
        this.author = author;
        this.price = price;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public String getAuthor() {
        return author;
    }
    public void setAuthor(String author) {
        this.author = author;
    }
    public double getPrice() {
        return price;
    }
    public void setPrice(double price) {
        this.price = price;
    }
    @Override
    public String toString() {
        return "Book{" +
                "name='" + name + '\'' +
                ", author='" + author + '\'' +
                ", price=" + price +
                '}';
    }
}

Address.java

public class Address {
    private String province;
    private String city;
    private String town;

    public Address() {
    }
    public Address(String province, String city, String town) {
        this.province = province;
        this.city = city;
        this.town = town;
    public String getProvince() {
        return province;
    public void setProvince(String province) {
    public String getCity() {
        return city;
    public void setCity(String city) {
    public String getTown() {
        return town;
    public void setTown(String town) {
    @Override
    public String toString() {
        return "Address{" +
                "province='" + province + '\'' +
                ", city='" + city + '\'' +
                ", town='" + town + '\'' +
                '}';
}

ioc.xml

给复杂类型的赋值都在property标签内进行
        1. 赋值为null
            <property name="name">
                <null></null>
            </property>
        2.外部引用 ref
        3.引用内部bean
        4.为list赋值
        5.为set赋值
            <property name="sets">
                <set>
                    <value>111</value>
                    <value>222</value>
                    <value>222</value>
                </set>
            </property>
        6。为map赋值
            <property name="maps" ref="myMap"></property>
            <util:map id="myMap">
                <entry key="key1" value="value1"></entry>
                <entry key="key2" value-ref="book2"></entry>
                <entry key="key03">
                    <bean class="com.yao.bean.Book">
                        <property name="name" value="西游记" ></property>
                        <property name="author" value="吴承恩" ></property>
                        <property name="price" value="100" ></property>
                    </bean>
                </entry>
            </util:map>
         7. 给数组赋值
            <property name="hobbies">
                <array>
                    <value>book</value>
                    <value>movie</value>
                    <value>game</value>
                </array>
            </property>

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

    <!--给复杂类型的赋值都在property标签内进行-->
    <bean id="person" class="com.mashibing.bean.Person">
        <property name="name">
            <!--赋空值-->
            <null></null>
        </property>
        <!--通过ref引用其他对象,引用外部bean-->
        <property name="address" ref="address"></property>
        <!--引用内部bean-->
       <!-- <property name="address">
            <bean class="com.mashibing.bean.Address">
                <property name="province" value="北京"></property>
                <property name="city" value="北京"></property>
                <property name="town" value="西城区"></property>
            </bean>
        </property>-->
        <!--为list赋值-->
        <property name="books">
            <list>
                <!--内部bean-->
                <bean id="book1" class="com.mashibing.bean.Book">
                    <property name="name" value="多线程与高并发"></property>
                    <property name="author" value="马士兵"></property>
                    <property name="price" value="1000"></property>
                </bean>
                <!--外部bean-->
                <ref bean="book2"></ref>
            </list>
        </property>
        <!--给map赋值-->
        <property name="maps" ref="myMap"></property>
        <!--给property赋值-->
        <property name="properties">
            <props>
                <prop key="aaa">aaa</prop>
                <prop key="bbb">222</prop>
            </props>
        </property>
        <!--给数组赋值-->
        <property name="hobbies">
            <array>
                <value>book</value>
                <value>movie</value>
                <value>game</value>
            </array>
        </property>
        <!--给set赋值-->
        <property name="sets">
            <set>
                <value>111</value>
                <value>222</value>
                <value>222</value>
            </set>
        </property>
    </bean>
    <bean id="address" class="com.mashibing.bean.Address">
        <property name="province" value="河北"></property>
        <property name="city" value="邯郸"></property>
        <property name="town" value="武安"></property>
    </bean>
    <bean id="book2" class="com.mashibing.bean.Book">
        <property name="name" value="JVM"></property>
        <property name="author" value="马士兵"></property>
        <property name="price" value="1200"></property>
    </bean>
    <!--级联属性-->
    <bean id="person2" class="com.mashibing.bean.Person">
        <property name="address" ref="address"></property>
        <property name="address.province" value="北京"></property>
    </bean>
    <!--util名称空间创建集合类型的bean-->
    <util:map id="myMap">
            <entry key="key1" value="value1"></entry>
            <entry key="key2" value-ref="book2"></entry>
            <entry key="key03">
                <bean class="com.mashibing.bean.Book">
                    <property name="name" value="西游记" ></property>
                    <property name="author" value="吴承恩" ></property>
                    <property name="price" value="100" ></property>
                </bean>
            </entry>
    </util:map>
</beans>

6、继承关系bean的配置(暂时用不到)

意思就是bean可以继承
parent:指定bean的配置信息继承于哪个bean
parson2继承parson 修改了name
abstract: 抽象bean,值在里面,还是有就是不能实例化。abstract="true"
自己演示一下,好像没啥用奥。
ioc.xml

 <bean id="person" class="com.mashibing.bean.Person">
        <property name="id" value="1"></property>
        <property name="name" value="zhangsan"></property>
        <property name="age" value="21"></property>
        <property name="gender" value="男"></property>
    </bean>
    <!--parent:指定bean的配置信息继承于哪个bean-->
    <bean id="person2" class="com.mashibing.bean.Person" parent="person">
        <property name="name" value="lisi"></property>
    </bean>

7、bean对象创建的依赖关系(暂时用不到)

bean对象在创建的时候是按照bean在配置文件的顺序决定的,也可以使用depend-on标签来决定顺序

  <bean id="book" class="com.mashibing.bean.Book" depends-on="person,address"></bean>
    <bean id="address" class="com.mashibing.bean.Address"></bean>
    <bean id="person" class="com.mashibing.bean.Person"></bean>

8、bean的作用域控制,是否是单例(一般两种)

细节点区别:(面试的时候细节点)
prototype:容器启动的时候不会创建多实例bean,只有在获取对象的时候才会创建该对象
singleton:在容器启动完成之前就已经创建好对象

 四种作用域
  singleton 单例(默认的模式)
  prototype 多例模式
  spring 4.x版本中:
  	request: 每次发送请求都有一个新的对象
  	session:每次发送会话都有一个新的对象
  	这两种方式几乎不用。
  测试singleton
  Person2 person2 = context.getBean("person2",Person.class);
  Person3 person3 = context.getBean("person3",Person.class);
  System.out.println(Person2== person3); // ture;

ioc.xml

  <!--
    bean的作用域:singleton、prototype、request、session
    默认情况下是单例的
    prototype:多实例的
        容器启动的时候不会创建多实例bean,只有在获取对象的时候才会创建该对象
        每次创建都是一个新的对象
    singleton:默认的单例对象
        在容器启动完成之前就已经创建好对象
        获取的所有对象都是同一个
    -->
    <bean id="person4" class="com.mashibing.bean.Person" scope="prototype"></bean>

9、利用工厂模式创建bean对象

静态工厂and实例工厂区别?
静态工厂:工厂本身不需要创建对象,但是可以通过静态方法调用,对象=工厂类.静态工厂方法名();
实例工厂:工厂本身需要创建对象,工厂类 工厂对象=new 工厂类;工厂对象.get对象名();
优缺点:
实例工厂更容易扩展。
PersonStaticFactory.java

 public class PersonStaticFactory { // 静态工厂类

      public static Person getPerson(String name){
          Person person = new Person();
          person.setId(1);
          person.setName(name);
          return person;
      }
  }

ioc.xml

<!--
静态工厂的使用:
class:指定静态工厂类
factory-method:指定哪个方法是工厂方法
-->
  <bean id="person5" class="com.mashibing.factory.PersonStaticFactory" factory-method="getPerson">
        <!--constructor-arg:可以为方法指定参数-->
        <constructor-arg value="lisi"></constructor-arg>
    </bean>

Test.java

工厂创建:用这个 不用PersonStaticFactory类,因为用的工厂方法创建的。
  Person2 person2 = context.getBean("person2",Person.class);
  System.out.println(Person2);

PersonInstanceFactory.java

 public class PersonInstanceFactory { // 实例工厂类 不加static!!
    public Person getPerson(String name){
        Person person = new Person();
        person.setId(1);
        person.setName(name);
        return person;
    }
  }

ioc.xml

 <!--实例工厂使用-->
    <!--创建实例工厂类-->
    <bean id="personInstanceFactory" class="com.mashibing.factory.PersonInstanceFactory"></bean>
    <!--
    factory-bean:指定使用哪个工厂实例
    factory-method:指定使用哪个工厂实例的方法
    -->
    <bean id="person6" class="com.mashibing.bean.Person" factory-bean="personInstanceFactory" factory-method="getPerson">
        <constructor-arg value="wangwu"></constructor-arg>
    </bean>

10、继承FactoryBean来创建对象(一般用不到,源码中看的多)

BeanFactory 接口,规范
  FactoryBean:获取唯一的对象。
      自己创建的对象也可交给spring管理。
      意思就是可以把我自己创建的交给Spring管理使用如下>
  使用:
      1)实现FactoryBean<那个类对象这里是person>接口
      2)三个方法:
          工厂方法,返回需要创建的对象
          返回对象的类型
          否是单例对象
      3)交给spring  配置ioc.xml下面有
  总结:
      创建对象的补充,用的时候才创建不用不会创建。跟单例多例没有关系
  自己不用。源码会用的多。

11、bean对象的初始化和销毁方法(了解)

初始化跟单例和多例有区别的:(一般没人使用,面试知道)
    如果bean是单例,容器在启动的时候会创建好,关闭的时候会销毁创建的bean
    如果bean是多例,获取的时候创建对象,销毁的时候不会有任何的调用

12、配置bean对象初始化方法的前后处理方法(了解)

POSTxxxx接口

13、spring创建第三方bean对象(配置数据库连接池)

1、导入数据库连接池的pom文件

<!-- https://mvnrepository.com/artifact/com.alibaba/druid -->
  <dependency>
      <groupId>com.alibaba</groupId>
      <artifactId>druid</artifactId>
      <version>1.1.21</version>
  </dependency>
  <!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
  <dependency>
      <groupId>mysql</groupId>
      <artifactId>mysql-connector-java</artifactId>
      <version>5.1.47</version>
  </dependency>

2、编写配置文件

 <?xml version="1.0" encoding="UTF-8"?>
  <beans xmlns="http://www.springframework.org/schema/beans"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
  <!--
  Spring管理第三方Bean对象
  -->
      <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource">
          <property name="username" value="root"></property>
          <property name="password" value="123456"></property>
          <property name="url" value="jdbc:mysql://localhost:3306/demo"></property>
          <property name="driverClassName" value="com.mysql.jdbc.Driver"></property>
      </bean>
  </beans>

3、编写测试文件

 public class MyTest {
      public static void main(String[] args) throws SQLException {
          ApplicationContext context = new ClassPathXmlApplicationContext("ioc3.xml");
          DruidDataSource dataSource = context.getBean("dataSource", DruidDataSource.class);
          System.out.println(dataSource);
          System.out.println(dataSource.getConnection());
      }
  }

4、spring引用外部配置文件

5、spring基于xml文件的自动装配

前面有address这个类,在ioc.xml中,就是用的propotery装配。
  现在自动装配:
  怎么实现的?
  byName:根据set方法后面首字幕大小写装配,必须首字幕小写。
  Type:按照类型装配,有多个一样的类型就报错。

当一个对象中需要引用另外一个对象的时候,在之前的配置中我们都是通过property标签来进行手动配置的,其实在spring中还提供了一个非常强大的功能就是自动装配,可以按照我们指定的规则进行配置,配置的方式有以下几种:

default/no:不自动装配

byName:按照名字进行装配,以属性名作为id去容器中查找组件,进行赋值,如果找不到则装配null

byType:按照类型进行装配,以属性的类型作为查找依据去容器中找到这个组件,如果有多个类型相同的bean对象,那么会报异常,如果找不到则装配null

constructor:按照构造器进行装配,先按照有参构造器参数的类型进行装配,没有就直接装配null;如果按照类型找到了多个,那么就使用参数名作为id继续匹配,找到就装配,找不到就装配null

6、SpEL的使用(就是简单语法糖,写bean方便)

略:只有公司要求让你用的时候你再去看,现在看了不用也没啥用。

7、SpringIOC的注解应用

Spring中注解标识:

Spring中包含4个主要的组件添加注解:
 @Controller:控制器,推荐给controller层添加此注解(接受用户请求 web用的到)
 @Service:业务逻辑,推荐给业务逻辑层添加此注解
 @Repository:仓库管理,推荐给数据访问层添加此注解
 @Component:给不属于以上基层的**组件**添加此注解(啥也不懂就加这个)

注解使用步骤

使用注解需要如下步骤:
 1、添加上述四个注解中的任意一个
 2、添加自动扫描注解的组件,此操作需要依赖context命名空间
 3、添加自动扫描的标签context:component-scan(当前包下面的所有类都进行扫描)

问题:在使用注解的时候咱们没有定义id和class他是怎么识别的呢?

默认类的名字首字母,小写,但是可以起别名,一般没人这么做,在注解标识括号中添加value = "xxxxxx",如@Controler(value = "类的名字就可以改");

扫描包可以做耕细粒度的划分(没啥用)

使用@AutoWired进行自动注入(理解困难,看看视频)

面试题:

注意:当使用AutoWired注解的时候,自动装配的时候是根据类型实现的。
  1、如果只找到一个,则直接进行赋值,
  2、如果没有找到,则直接抛出异常,
  3、如果找到多个,那么会按照变量名作为id继续匹配,
    1、匹配上直接进行装配
    2、如果匹配不上则直接报异常

还可以使用@Qualifier注解来指定id的名称,让spring不要使用变量名,当使用@Qualifier注解的时候也会有两种情况:
  1、找到,则直接装配
​  2、找不到,就会报错

@AutoWired可以进行定义在方法上

自动装配的注解@AutoWired,@Resource

面试题:

在使用自动装配的时候,出了可以使用@AutoWired注解之外,还可以使用@Resource注解,大家需要知道这**两个注解的区别**。
​        1、@AutoWired:是spring中提供的注解,@Resource:是jdk中定义的注解,依靠的是java的标准
​        2、@AutoWired默认是按照类型进行装配,默认情况下要求依赖的对象必须存在,@Resource默认是按照名字进行匹配的,同时可以指定name属性。
​        3、@AutoWired只适合spring框架,而@Resource扩展性更好

6、泛型依赖注入(先跳过把)

到此这篇关于Spring从入门到源码—IOC基本使用(二)的文章就介绍到这了,更多相关Spring入门IOC内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Spring IOC源码剖析_如何整体认知Spring体系结构

    目录 如何整体认知Spring体系结构 一.来自官网的Spring 二.Spring的优缺点 三.一张图理解Spring Framework 4.x 四.详解"七层"宝塔 1. 核心容器(Core Container) 2. 数据访问/集成(Data Access/Integration)层 3. Web层 4. AOP(Aspect Oriented Programming)模块 5. 植入(Instrumentation)模块 6. 消息传输(Messaging) 7. 测试(Te

  • Spring IOC源码之bean的注册过程讲解

    目录 BeanDefition加载注册过程 进入obtainFreshBeanFactory方法 ​进入AbstractRefreshableApplicationContext类中的refreshBeanFactory方法 进入AbstractXmlApplicationContext类的loadBeanDefinitions方法 进入doLoadBeanDefinitions方法 Spring IoC--Bean的创建和初始化 Spring介绍 IoC介绍 IoC是什么 IoC能做什么 源码

  • Spring从入门到源码之IOC基本用法

    1.spring_helloworld 使用maven的方式来构建项目(Mavaen) 添加对应的pom依赖pom.xml <dependencies> <!-- https://mvnrepository.com/artifact/org.springframework/spring-context --> <dependency> <groupId>org.springframework</groupId> <artifactId>

  • Spring启动流程refresh()源码深入解析

    一.Spring容器的refresh() spring  version:4.3.12  ,尚硅谷Spring注解驱动开发-源码部分 //refresh():543, AbstractApplicationContext (org.springframework.context.support) public void refresh() throws BeansException, IllegalStateException { synchronized (this.startupShutdo

  • lazy init控制加载在Spring中如何实现源码分析

    目录 一.lazy-init说明 二.lazy-init 属性被设置的地方 三.lazy-init发挥作用的地方 四.问答 一.lazy-init说明 ApplicationContext实现的默认行为就是在启动时将所有singleton bean提前进行实例化(也就是依赖注入). 提前实例化意味着作为初始化过程的一部分,ApplicationContext实例会创建并配置所有的singleton bean. 通常情况下这是件好事,因为这样在配置中的任何错误就会即刻被发现(否则的话可能要花几个小

  • Android入门之源码开发基础教程

    本文讲述了Android入门之源码开发基础教程.分享给大家供大家参考,具体如下: 下载 Android 源码之后,接下来就是学习或者进行开发. 在开发之前,谈一些开发必备知识或者工具,工欲善其事必先利其器嘛! 在前面一篇<Android入门之使用eclipse进行源码开发的方法>中基本上说了开发使用工具. 但是我们如何使用模拟器开发呢?! 当然你去删除或者增加app到模拟器就不可以按常规来操作了,花 5 -10 分钟了解一下,如果你有需要. 0. 编译源码 直接在下载的源码根目录下面,执行:

  • spring获取bean的源码解析

    介绍 前面一章说了AbstractApplicationContext中的refresh方法中的invokeBeanFactoryPostProcessors.主要是调用BeanFactoryPostProcessor.其中也有获取bean的过程,就是beanFactory.getBean的方法.这一章就说下getBean这个方法.由于spring中获取bean的方法比较复杂,涉及到的流程也非常多,这一章就先说下整个大体的流程.其中的细节会在后面也会慢慢说. 源码 直接看源码吧 @Overrid

  • Java Spring @Lazy延迟注入源码案例详解

    前言 有时候我们会在属性注入的时候添加@Lazy注解实现延迟注入,今天咱们通过阅读源码来分析下原因 一.一个简单的小例子 代码如下: @Service public class NormalService1 { @Autowired @Lazy private MyService myService; public void doSomething() { myService.getName(); } } 作用是为了进行延迟加载,在NormalService1进行属性注入的时候,如果MyServ

  • 深入解析spring AOP原理及源码

    目录 @EnableAspectJAutoProxy 找切面 代理对象的创建 代理方法的执行 ExposeInvocationInterceptor#invoke 环绕通知的执行 前置通知的执行 后置通知的执行 返回后通知的执行 异常通知的执行 @EnableAspectJAutoProxy @EnableAspectJAutoProxy注解用于开启AOP功能,那么这个注解底层到底做了什么呢? 查看@EnableAspectJAutoProxy的源码,发现它使用@Import注解向Spring容

  • 基于Gradle搭建Spring 5.3.13-release源码阅读环境的详细流程

    目录 # 1.安装JDK # 2.安装Gradle # 3.Spring版本命名规则 # 4.下载Spring 5.3.13-release源码 # 5.修改Spring源码中Gradle配置 # 6.构建Spring源码 # 7.导入IDEA 点击File --> New --> Project from Existing Sources... # 8.创建Spring源码debug调试模块 # 基于Gradle搭建Spring 5.5.13-release源码阅读环境 Spring版本:5

  • Java源码角度分析HashMap用法

    -HashMap- 优点:超级快速的查询速度,时间复杂度可以达到O(1)的数据结构非HashMap莫属.动态的可变长存储数据(相对于数组而言). 缺点:需要额外计算一次hash值,如果处理不当会占用额外的空间. -HashMap如何使用- 平时我们使用hashmap如下 Map<Integer,String> maps=new HashMap<Integer,String>(); maps.put(1, "a"); maps.put(2, "b&quo

  • 基于Spring Boot的Environment源码理解实现分散配置详解

    前提 org.springframework.core.env.Environment是当前应用运行环境的公开接口,主要包括应用程序运行环境的两个关键方面:配置文件(profiles)和属性.Environment继承自接口PropertyResolver,而PropertyResolver提供了属性访问的相关方法.这篇文章从源码的角度分析Environment的存储容器和加载流程,然后基于源码的理解给出一个生产级别的扩展. 本文较长,请用一个舒服的姿势阅读. Environment类体系 Pr

随机推荐