Spring @autowired註解

1、在接口實現類中,使用到@Autowired 註解,下面是該註解使用的類

2、Spring@Autowired註解與自動裝配

@Autowired顧名思義,就是自動裝配,其作用是爲了消除代碼Java代碼裏面的getter/setter與bean屬性中的property。當然,getter看個人需求,如果私有屬性需要對外提供的話,應當予以保留。

 

這個註解就是spring可以自動幫你把bean裏面引用的對象的setter/getter方法省略,它會自動幫你set/get。

 

其實在啓動spring IoC時,容器自動裝載了一個AutowiredAnnotationBeanPostProcessor後置處理器,當容器掃描到@Autowied、@Resource或@Inject時,就會在IoC容器自動查找需要的bean,並裝配給該對象的屬性

 

3、@Autowired 可以對成員變量、方法以及構造函數進行註釋。那麼對成員變量和構造函數進行註釋又有什麼區別呢?

@Autowired和構造方法執行的順序解析

  先看一段代碼,下面的代碼能運行成功嗎?

 @Autowired
 private User user;
 private String school;

 public UserAccountServiceImpl(){
     this.school = user.getSchool();
 }

  答案是不能。

  因爲Java類會先執行構造方法,然後再給註解了@Autowired 的user注入值,所以在執行構造方法的時候,就會報錯。

  報錯信息可能會像下面: 

Exception in thread "main" org.springframework.beans.factory.BeanCreationException: 
Error creating bean with name ‘...‘ defined in file [....class]: Instantiation of bean failed; 
nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate 
[...]: Constructor threw exception; nested exception is java.lang.NullPointerException

報錯信息說:創建Bean時出錯,出錯原因是實例化bean失敗,因爲bean時構造方法出錯,在構造方法裏拋出了空指針異常。

  解決辦法是,使用構造器注入,如下:

 private User user;
 private String school;

 @Autowired
 public UserAccountServiceImpl(User user){
     this.user = user;
     this.school = user.getSchool();
 }

 可以看出,使用構造器注入的方法,可以明確成員變量的加載順序。

  PS:Java變量的初始化順序爲:靜態變量或靜態語句塊–>實例變量或初始化語句塊–>構造方法–>@Autowired

      @Autowired本身就是單例模式,只會在程序啓動時執行一次,即使不定義final也不會初始化第二次,所以這個final是沒有意義的吧。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章