亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Spring使用@Autowired注解實現(xiàn)自動裝配方式

 更新時間:2021年09月27日 11:44:05   作者:想飛的魚Stitch  
這篇文章主要介紹了Spring使用@Autowired注解實現(xiàn)自動裝配方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

Spring支持注解配置

引入注解依賴

<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">

啟用注解

<context:annotation-config/>

使用@Autowired注解實現(xiàn)自動裝配

1、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"
      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">
      <context:annotation-config/>
   <bean id="cat" class="indi.stitch.pojo.Cat"/>
   <bean id="dog" class="indi.stitch.pojo.Dog"/>
   <bean id="people" class="indi.stitch.pojo.People" />
</beans>

2、實體類使用@Autowired注解注入屬性

package indi.stitch.pojo;
import org.springframework.beans.factory.annotation.Autowired;
public class People {
    @Autowired
    private Cat cat;
    @Autowired
    private Dog dog;
    public Cat getCat() {
        return cat;
    }
    public Dog getDog() {
        return dog;
    }
    @Override
    public String toString() {
        return "People{" +
                "cat=" + cat +
                ", dog=" + dog +
                '}';
    }
}

Cat實體類

package indi.stitch.pojo;
public class Cat {
    public void shout() {
        System.out.println("miao~");
    }
}

Dog實體類

package indi.stitch.pojo;
public class Dog {
    public void shout() {
        System.out.println("wang~");
    }
}

使用@Autowired注解支持自動注入后,可以省略實體類的setter方法

3、測試結(jié)果

在這里插入圖片描述

使用Java類庫中的@Resource注解可以實現(xiàn)相同的效果,@Autowired和@Resource注解的區(qū)別是

  • @Autowired注解默認按byType方式實現(xiàn),@Resource注解默認按byName方式實現(xiàn)
  • @Autowired注解在IOC容器中配置了多個相同類型的bean時,需要配合@Qualifier找到唯一bean
@Autowired
@Qualifier("cat")
private Cat cat;

@Resource注解可以配置name和type屬性進行bean的注入

@Resource(name = "dog", type = Dog.class)
private Dog dog;


@Resource屬性單獨使用name屬性后,將不會按照byType方式查找bean,@Autowired注解可以使用required屬性來決定注入的屬性是否允許為空

@Autowired(required = false)
 @Qualifier("cat")
 private Cat cat;

@Autowired注解的使用和注入規(guī)則

作為一個Spring開發(fā)者對@Autowired注解必定是非常了解了, 顧名思義自動裝配,應(yīng)該是Spring會自動將我們標記為@Autowired的元素裝配好,與其猜測不如看看它的定義:

@Target({ElementType.CONSTRUCTOR, ElementType.METHOD, ElementType.PARAMETER, ElementType.FIELD, ElementType.ANNOTATION_TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface Autowired { 
  boolean required() default true; 
}

很明顯這個注解可以用到構(gòu)造器,變量域,方法,注解類型和方法參數(shù)上。文檔上這樣描述:將一個構(gòu)造器,變量域,setter方法,config方法標記為被Spring DI 工具自動裝配。換句話說,在Spring創(chuàng)建bean的過程中,會為這個bean中標有@Autowired注解的構(gòu)造器,變量域,方法和方法參數(shù)中自動注入我們需要的已經(jīng)在Spring IOC容器里面的bean,,而無需我們手動完成,并且注入的bean都是單實例,也就是在兩個bean中都依賴第三個bean,那么這兩個bean中注入的第三個bean會是同一個bean(JVM中指向的地址相同)。

在@Autowired注解里面有一個required屬性,該屬性默認為true,當為true時,表示去Spring IOC中查找相應(yīng)的bean,如果找不到,則會報錯,如果為false時,表示去Spring IOC中查找相應(yīng)的bean,如果找不到,則直接忽略,不再進行注入。

@Autowired注解的注入規(guī)則:默認按照類型進行注入,如果IOC容器中存在兩個及以上的相同類型的bean時,根據(jù)bean的名稱進行注入,如果沒有指定名稱的bean,則會報錯。

可以使用@Qualifier("wheel")來使用指定id的bean,也可以在注入bean時,添加@Primary注解,優(yōu)先添加一個bean,其規(guī)則如下:

如果指定添加了@Qualifier("wheel")則按照指定的bean id進行添加(優(yōu)先級最高),找不到則直接報錯。如果沒有添加@Qualifier而添加了@Primary注解,則首先添加標注了@Primary注解的bean。當即存在@Qualifier注解也存在@Primary注解注解,則按照@Qualifier指定的bean id注入,找不到直接報錯。

很多人java開發(fā)者都知道@Autowired注解,但是真正用的好的也不多(反正系統(tǒng)的學習Spring之前我是不知道的),那下面讓我們來看一下@Autowired的用法:

1.使用在變量域上面

這個相信大家都已經(jīng)清楚了,Spring會幫我們注入我們想要的bean,看下面的例子:

package it.cast.circularDependency; 
@Component
public class Wheel { 
}
 
@Component
public class Car { 
    @Autowired
    private Wheel wheel2;
 
    public Wheel getWheel() {
        return wheel2;
    }
 
    public void setWheel(Wheel wheel2) {
        this.wheel2 = wheel2;
    }
}
 
@ComponentScan({"it.cast.circularDependency"})
public class AutowiredConfig { 
}

下面進行測試,打印的結(jié)果顯示可以拿到Wheel類,說明@Autowired注解在IOC容器中只有一個類型的bean時,按照類型進行注入。

@Test
    public void AutowiredConfigTest(){
        AnnotationConfigApplicationContext context =
                new AnnotationConfigApplicationContext(AutowiredConfig.class); 
        Car bean = context.getBean(Car.class);
        System.out.println(bean.getWheel());
    }
 
//打印結(jié)果:
//   it.cast.circularDependency.Wheel@3eb25e1a

下面看一下當IOC容器中有兩個Wheel類型的bean時的情況,改造Wheel類,增加一個屬性標識用于記錄向Car類中注入的哪個Wheel的bean,在AutowiredConfig配置類中添加一個bean,bean的名稱默認為方法名,也就是wheel1。

@Component
public class Wheel {
    private int num = 2;   //通過包掃描的方式注入的bean的num值為2 
    public int getNum() {
        return num;
    } 
    public void setNum(int num) {
        this.num = num;
    }
}
 
@Component
public class Car { 
    @Autowired
    private Wheel wheel3;//將變量名改成wheel3,IOC容器中Wheel類型的bean的名稱只有wheel和wheel1 
    public Wheel getWheel() {
        return wheel3;
    } 
    public void setWheel(Wheel wheel3) {
        this.wheel3 = wheel3;
    }
} 
 
@Configuration
@ComponentScan({"it.cast.circularDependency"})
public class AutowiredConfig {
 
    @Bean
    public Wheel wheel1(){ 
        Wheel wheel = new Wheel();//通過配置類注入bean的方式num值為0
        wheel.setNum(0);
        return wheel;
    }
}

這時在Spring IOC中有兩個Wheel類型的bean了,Car在注入Wheel類型的bean時,會根據(jù)變量名wheel3去找,也就是說會去找類型為Wheel,名稱為wheel3的bean,顯然是找不到的,也就會報錯。

Exception encountered during context initialization - cancelling refresh attempt:
org.springframework.beans.factory.UnsatisfiedDependencyException:
Error creating bean with name 'car':
Unsatisfied dependency expressed through field 'wheel3';
nested exception is org.springframework.beans.factory.NoUniqueBeanDefinitionException:
No qualifying bean of type 'it.cast.circularDependency.Wheel' available:
expected single matching bean but found 2: wheel,wheel1

org.springframework.beans.factory.UnsatisfiedDependencyException:
Error creating bean with name 'car': Unsatisfied dependency expressed through field 'wheel3';
nested exception is org.springframework.beans.factory.NoUniqueBeanDefinitionException:
No qualifying bean of type 'it.cast.circularDependency.Wheel' available:
expected single matching bean but found 2: wheel,wheel1

上面為報錯的日志打印,大致意思說的在創(chuàng)建名稱為car的bean時,不能為變量域wheel3完成屬性注入,因為找到了兩個bean,分別是wheel和wheel1。

如果我們把Car中的wheel3換成wheel就可以完成注入了,而且注入的bean是通過包掃描注入IOC的bean:

@Component
public class Wheel {
    private int num = 2;   //通過包掃描的方式注入的bean的num值為2 
    public int getNum() {
        return num;
    } 
    public void setNum(int num) {
        this.num = num;
    }
}
 
@Component
public class Car { 
    @Autowired
    private Wheel wheel;//將變量名改成wheel1,IOC容器中Wheel類型的bean的名稱只有wheel和wheel1 
    public Wheel getWheel() {
        return wheel;
    } 
    public void setWheel(Wheel wheel3) {
        this.wheel = wheel;
    }
} 
 
@Configuration
@ComponentScan({"it.cast.circularDependency"})
public class AutowiredConfig { 
    @Bean
    public Wheel wheel1(){ 
        Wheel wheel = new Wheel();//通過配置類注入bean的方式num值為0
        wheel.setNum(0);
        return wheel;
    }
}

在測試類中打印num值看看注入的是哪個bean:

@Test
    public void AutowiredConfigTest(){
        AnnotationConfigApplicationContext context =
                new AnnotationConfigApplicationContext(AutowiredConfig.class);
 
        Car bean = context.getBean(Car.class);
        System.out.println(bean.getWheel().getNum());
    } 
//打印結(jié)果:
//    2

那么就驗證了上面所說的注入規(guī)則:默認按照類型進行注入,如果IOC容器中存在兩個及以上的相同類型的bean時,根據(jù)bean的名稱進行注入,如果沒有指定名稱的bean,則會報錯。

@Autowired注解使用在變量域中還可以解決循環(huán)依賴的問題,循環(huán)依賴問題就是A對象中注入了B對象,B對象中注入了A對象,循環(huán)依賴在面試Spring這一塊的知識應(yīng)該經(jīng)常會被問題,關(guān)于循環(huán)依賴的問題,在后面的博客中會更新。

2.@Autowired注解使用在構(gòu)造器上面

@Autowired使用在構(gòu)造器上面有幾條需要特別注意的點:

1.@Autowired標注在構(gòu)造器上面不能解決循環(huán)依賴構(gòu)造的問題

2.@Autowired可以標注在同一個類的多個構(gòu)造器上面,但是required屬性必須都為false,當required有一個為true時,不允許其他構(gòu)造器標有@Autowired注解,即使required屬性為false也不行。

@Component
public class A {
    private B b;
    private C c;
 
    @Autowired
    public A(B b, C c) {
        System.out.println("b=" + b + ", c=" + c);
        this.b = b;
        this.c = c;
    }
}
 
@Component
public class B { 
} 
@Component
public class C {
}
 
//打印結(jié)果:
//  b=it.cast.circularDependency.B@68e965f5, c=it.cast.circularDependency.C@6f27a732

@Autowired標注在構(gòu)造器上面,在B創(chuàng)建的過程中,會去Spring IOC中拿到需要的注入的bean,完成B的創(chuàng)建,其實在只有一個構(gòu)造器的情況中,@Autowired可以不加,因為Spring內(nèi)部有自動推斷構(gòu)造器的能力,這個如果想了解自動推斷構(gòu)造器的同學可以自行百度(實在是太難了,一臉蒙蔽)。

下面看一個構(gòu)造器循壞依賴的案例:

@Component
public class C {
    private B b; 
    public C(B b) {
        this.b = b;
    }
}
 
@Component
public class B {
    private C c; 
    public B(C c) {
        this.c = c;
    }
}

Spring目前不能解決構(gòu)造器的循環(huán)依賴,所以在項目中使用的時候要格外注意一下,錯誤日志:

org.springframework.beans.factory.UnsatisfiedDependencyException:
Error creating bean with name 'a' defined in file
[E:\IdeaProjects\javaBasis\spring\target\classes\it\cast\circularDependency\A.class]:
Unsatisfied dependency expressed through constructor parameter 0;
nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException:
Error creating bean with name 'b' defined in file
[E:\IdeaProjects\javaBasis\spring\target\classes\it\cast\circularDependency\B.class]:
Unsatisfied dependency expressed through constructor parameter 0;
nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException:
Error creating bean with name 'c' defined in file
[E:\IdeaProjects\javaBasis\spring\target\classes\it\cast\circularDependency\C.class]:
Unsatisfied dependency expressed through constructor parameter 0;
nested exception is org.springframework.beans.factory.BeanCurrentlyInCreationException:
Error creating bean with name 'b':
Requested bean is currently in creation: Is there an unresolvable circular reference?

下面看一下關(guān)于多個@Autowired標注的構(gòu)造器的案例:

@Component
public class A {
    private B b;
    private C c; 
    @Autowired(required = false)
    public A(B b) {
        this.b = b;
    }
 
    @Autowired
    public A(B b, C c) {
        System.out.println("b=" + b + ", c=" + c);
        this.b = b;
        this.c = c;
    }
} 
@Component
public class B { 
} 
@Component
public class C { 
}

上面已經(jīng)說到,如果@Autowired注解的屬性required為true時,不允許再出現(xiàn)其他構(gòu)造器上面標有@Autowired注解(@Autowired注解的required默認為true,所以上面的會報錯),錯誤日志為:

org.springframework.beans.factory.BeanCreationException:
Error creating bean with name 'a': Invalid autowire-marked constructors:
[public it.cast.circularDependency.A(it.cast.circularDependency.B)].
Found constructor with 'required' Autowired annotation:
public it.cast.circularDependency.A(it.cast.circularDependency.B,it.cast.circularDependency.C)

使用下面的寫法就不會出現(xiàn)錯誤了,Spring支持多個構(gòu)造器有@Autowired注解,但是required屬性必須都是false

@Component
public class A {
    private B b;
    private C c;
 
    @Autowired(required = false) 
    public A(B b) {
        this.b = b;
    }
 
    @Autowired(required = false)
    public A(B b, C c) {
        System.out.println("b=" + b + ", c=" + c);
        this.b = b;
        this.c = c;
    }
}
 
@Component
public class B { 
} 
@Component
public class C { 
}

關(guān)于@Autowired標注在方法上就不多介紹,會首先拿到方法的參數(shù)列表,然后根據(jù)上面所說的注入規(guī)則去Spring IOC中找相應(yīng)的bean。

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • java中使用sax解析xml的解決方法

    java中使用sax解析xml的解決方法

    本篇文章介紹了,在java中使用sax解析xml的解決方法。需要的朋友參考下
    2013-05-05
  • Java中@InitBinder注解的使用原理詳解

    Java中@InitBinder注解的使用原理詳解

    這篇文章主要介紹了Java中@InitBinder注解的使用原理詳解,在Java中,@InitBinder 注解是用于標記一個方法,該方法將在控制器(Controller)處理請求之前被調(diào)用,用于進行一些數(shù)據(jù)綁定和預處理的操作,需要的朋友可以參考下
    2023-10-10
  • Javacsv實現(xiàn)Java讀寫csv文件

    Javacsv實現(xiàn)Java讀寫csv文件

    這篇文章主要為大家詳細介紹了Javacsv實現(xiàn)Java讀寫csv文件,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-07-07
  • IDEA的Web項目右鍵無法創(chuàng)建Servlet問題解決辦法

    IDEA的Web項目右鍵無法創(chuàng)建Servlet問題解決辦法

    這篇文章主要介紹了IDEA的Web項目右鍵無法創(chuàng)建Servlet問題解決辦法的相關(guān)資料,在IDEA中新建Servlet時發(fā)現(xiàn)缺失選項,可以通過在pom.xml文件中添加servlet依賴解決,文中通過圖文介紹的非常詳細,需要的朋友可以參考下
    2024-10-10
  • RateLimiter 源碼分析

    RateLimiter 源碼分析

    本文主要對ratelimiter的常用方法以及源碼進行了分析解讀,具有一定參考價值,需要的朋友可以了解下。
    2017-09-09
  • JVM代碼緩存區(qū)CodeCache原理及用法解析

    JVM代碼緩存區(qū)CodeCache原理及用法解析

    這篇文章主要介紹了JVM代碼緩存區(qū)CodeCache原理及用法解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-11-11
  • java?環(huán)境配置(2023年詳細教程)

    java?環(huán)境配置(2023年詳細教程)

    這篇文章首先為了完善我的知識體系,今后一些軟件的安裝教程也可能會用到想寫一個更加詳細的,因為這并不僅僅是寫給?IT?行業(yè)的,其它行業(yè)可能也需要配置java環(huán)境
    2023-06-06
  • 解決Weblogic部署war找不到spring配置文件的問題

    解決Weblogic部署war找不到spring配置文件的問題

    這篇文章主要介紹了解決Weblogic部署war找不到spring配置文件的問題,具有很好的參考價值,希望對大家有所幫助。
    2021-07-07
  • java實現(xiàn)大數(shù)加法(BigDecimal)的實例代碼

    java實現(xiàn)大數(shù)加法(BigDecimal)的實例代碼

    之前寫過用vector、string實現(xiàn)大數(shù)加法,現(xiàn)在用java的BigDecimal類,代碼簡單很多。但是在online-judge上,java的代碼運行時間和內(nèi)存大得多
    2013-10-10
  • Mybatis?Plus?中的LambdaQueryWrapper示例詳解

    Mybatis?Plus?中的LambdaQueryWrapper示例詳解

    這篇文章主要介紹了Mybatis?Plus?中的LambdaQueryWrapper,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-03-03

最新評論