Spring入門到精通之Bean標簽詳解
Bean標簽基本配置
用于配置對象交由Spring 來創(chuàng)建。 默認情況下它調(diào)用的是類中的無參構(gòu)造函數(shù),如果沒有無參構(gòu)造函數(shù)則不能創(chuàng)建成功。
基本屬性: id:Bean實例在Spring容器中的唯一標識 class:Bean的全限定名稱
Bean標簽范圍配置
scope:指對象的作用范圍,取值如下:
取值范圍 | 說明 |
---|---|
singleton | 默認值,單例的 |
prototype | 多例的 |
request | WEB 項目中,Spring 創(chuàng)建一個 Bean 的對象,將對象存入到 request 域中 |
session | WEB 項目中,Spring 創(chuàng)建一個 Bean 的對象,將對象存入到 session 域中 |
global session | WEB 項目中,應用在 Portlet 環(huán)境,如果沒有 Portlet 環(huán)境那么globalSession 相當于 session |
1)當scope的取值為singleton時
Bean的實例化個數(shù):1個
Bean的實例化時機:當Spring核心文件被加載時,實例化配置的Bean實例
Bean的生命周期:
對象創(chuàng)建:當應用加載,創(chuàng)建容器時,對象就被創(chuàng)建了
對象運行:只要容器在,對象一直活著
對象銷毀:當應用卸載,銷毀容器時,對象就被銷毀了
2)當scope的取值為prototype時
Bean的實例化個數(shù):多個
Bean的實例化時機:當調(diào)用getBean()方法時實例化Bean
對象創(chuàng)建:當使用對象時,創(chuàng)建新的對象實例
對象運行:只要對象在使用中,就一直活著
對象銷毀:當對象長時間不用時,被 Java 的垃圾回收器回收了
Bean生命周期配置
init-method:指定類中的初始化方法名稱
destroy-method:指定類中銷毀方法名稱
Bean的依賴注入入門
①創(chuàng)建 UserService,UserService 內(nèi)部在調(diào)用 UserDao的save() 方法
public class UserServiceImpl implements UserService { @Override public void save() { ApplicationContext applicationContext = new ClassPathXmlApplicationContext("applicationContext.xml"); UserDao userDao = (UserDao) applicationContext.getBean("userDao"); userDao.save(); } }
②將 UserServiceImpl 的創(chuàng)建權交給 Spring
<bean id="userService" class="com.zjq.service.impl.UserServiceImpl"/>
③從 Spring 容器中獲得 UserService 進行操作
ApplicationContext applicationContext = new ClassPathXmlApplicationContext("applicationContext.xml"); UserService userService = (UserService) applicationContext.getBean("userService"); userService.save();
Bean的依賴注入概念
依賴注入(Dependency Injection):它是 Spring 框架核心 IOC 的具體實現(xiàn)。
在編寫程序時,通過控制反轉(zhuǎn),把對象的創(chuàng)建交給了 Spring,但是代碼中不可能出現(xiàn)沒有依賴的情況。
IOC 解耦只是降低他們的依賴關系,但不會消除。例如:業(yè)務層仍會調(diào)用持久層的方法。
那這種業(yè)務層和持久層的依賴關系,在使用 Spring 之后,就讓 Spring 來維護了。
簡單的說,就是坐等框架把持久層對象傳入業(yè)務層,而不用我們自己去獲取
Bean的依賴注入方式
①構(gòu)造方法
創(chuàng)建有參構(gòu)造
public class UserServiceImpl implements UserService { @Override public void save() { ApplicationContext applicationContext = new ClassPathXmlApplicationContext("applicationContext.xml"); UserDao userDao = (UserDao) applicationContext.getBean("userDao"); userDao.save(); } }
配置Spring容器調(diào)用有參構(gòu)造時進行注入
<bean id="userDao" class="com.zjq.dao.impl.UserDaoImpl"/> <bean id="userService" class="com.zjq.service.impl.UserServiceImpl"> <constructor-arg name="userDao" ref="userDao"></constructor-arg> </bean>
②set方法
在UserServiceImpl中添加setUserDao方法
public class UserServiceImpl implements UserService { private UserDao userDao; public void setUserDao(UserDao userDao) { this.userDao = userDao; } @Override public void save() { userDao.save(); } }
配置Spring容器調(diào)用set方法進行注入
<bean id="userDao" class="com.zjq.dao.impl.UserDaoImpl"/> <bean id="userService" class="com.zjq.service.impl.UserServiceImpl"> <property name="userDao" ref="userDao"/> </bean>
set方法:P命名空間注入
P命名空間注入本質(zhì)也是set方法注入,但比起上述的set方法注入更加方便,主要體現(xiàn)在配置文件中,如下:
首先,需要引入P命名空間:
xmlns:p="http://www.springframework.org/schema/p"
其次,需要修改注入方式
<bean id="userService" class="com.zjq.service.impl.UserServiceImpl" p:userDao- ref="userDao"/>
Bean的依賴注入的數(shù)據(jù)類型
上面的操作,都是注入的引用Bean,除了對象的引用可以注入,普通數(shù)據(jù)類型,集合等都可以在容器中進行注入。
注入數(shù)據(jù)的三種數(shù)據(jù)類型
- 普通數(shù)據(jù)類型
- 引用數(shù)據(jù)類型
- 集合數(shù)據(jù)類型
其中引用數(shù)據(jù)類型,此處就不再贅述了,之前的操作都是對UserDao對象的引用進行注入的,下面將以set方法注入為例,演示普通數(shù)據(jù)類型和集合數(shù)據(jù)類型的注入。
(1)普通數(shù)據(jù)類型的注入
public class UserDaoImpl implements UserDao { private String company; private int age; public void setCompany(String company) { this.company = company; } public void setAge(int age) { this.age = age; } public void save() { System.out.println(company+"==="+age); System.out.println("UserDao save method running...."); } }
<bean id="userDao" class="com.zjq.dao.impl.UserDaoImpl"> <property name="company" value="huawei"></property> <property name="age" value="15"></property> </bean>
(2)集合數(shù)據(jù)類型(List)的注入
public class UserDaoImpl implements UserDao { private List<String> strList; public void setStrList(List<String> strList) { this.strList = strList; } public void save() { System.out.println(strList); System.out.println("UserDao save method running...."); } }
<bean id="userDao" class="com.zjq.dao.impl.UserDaoImpl"> <property name="strList"> <list> <value>aaa</value> <value>bbb</value> <value>ccc</value> </list> </property> </bean>
(3)集合數(shù)據(jù)類型(List)的注入
public class UserDaoImpl implements UserDao { private List<User> userList; public void setUserList(List<User> userList) { this.userList = userList; } public void save() { System.out.println(userList); System.out.println("UserDao save method running...."); } }
<bean id="u1" class="com.zjq.domain.User"/> <bean id="u2" class="com.zjq.domain.User"/> <bean id="userDao" class="com.zjq.dao.impl.UserDaoImpl"> <property name="userList"> <list> <bean class="com.zjq.domain.User"/> <bean class="com.zjq.domain.User"/> <ref bean="u1"/> <ref bean="u2"/> </list> </property> </bean>
(4)集合數(shù)據(jù)類型( Map<String,User> )的注入
public class UserDaoImpl implements UserDao { private Map<String,User> userMap; public void setUserMap(Map<String, User> userMap) { this.userMap = userMap; } public void save() { System.out.println(userMap); System.out.println("UserDao save method running...."); } }
<bean id="u1" class="com.zjq.domain.User"/> <bean id="u2" class="com.zjq.domain.User"/> <bean id="userDao" class="com.zjq.dao.impl.UserDaoImpl"> <property name="userMap"> <map> <entry key="user1" value-ref="u1"/> <entry key="user2" value-ref="u2"/> </map> </property> </bean>
(5)集合數(shù)據(jù)類型(Properties)的注入
public class UserDaoImpl implements UserDao { private Properties properties; public void setProperties(Properties properties) { this.properties = properties; } public void save() { System.out.println(properties); System.out.println("UserDao save method running...."); } }
<bean id="userDao" class="com.zjq.dao.impl.UserDaoImpl"> <property name="properties"> <props> <prop key="p1">aaa</prop> <prop key="p2">bbb</prop> <prop key="p3">ccc</prop> </props> </property> </bean>
引入其他配置文件(分模塊開發(fā))
實際開發(fā)中,Spring的配置內(nèi)容非常多,這就導致Spring配置很繁雜且體積很大,所以,可以將部分配置拆解到其他配置文件中,而在Spring主配置文件通過import標簽進行加載
<import resource="applicationContext-xxx.xml"/>
到此這篇關于Spring入門到精通之Bean標簽詳解的文章就介紹到這了,更多相關Spring Bean標簽內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
java普通項目讀取不到resources目錄下資源文件的解決辦法
這篇文章主要給大家介紹了關于java普通項目讀取不到resources目錄下資源文件的解決辦法,Web項目中應該經(jīng)常有這樣的需求,在maven項目的resources目錄下放一些文件,比如一些配置文件,資源文件等,需要的朋友可以參考下2023-09-09SpringCloud OpenFeign Post請求400錯誤解決方案
這篇文章主要介紹了SpringCloud OpenFeign Post請求400錯誤解決方案,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-09-09spring boot @PathVariable傳遞帶反斜杠參數(shù) / 的處理
這篇文章主要介紹了spring boot @PathVariable傳遞帶反斜杠參數(shù) / 的處理操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-02-02Java數(shù)據(jù)結(jié)構(gòu)順序表用法詳解
順序表是計算機內(nèi)存中以數(shù)組的形式保存的線性表,線性表的順序存儲是指用一組地址連續(xù)的存儲單元依次存儲線性表中的各個元素、使得線性表中在邏輯結(jié)構(gòu)上相鄰的數(shù)據(jù)元素存儲在相鄰的物理存儲單元中,即通過數(shù)據(jù)元素物理存儲的相鄰關系來反映數(shù)據(jù)元素之間邏輯上的相鄰關系2021-10-10Java實現(xiàn)線程按序交替執(zhí)行的方法詳解
這篇文章主要為大家詳細介紹了Java如何實現(xiàn)線程按序交替執(zhí)行,文中的示例代碼講解詳細,對我們了解線程有一定幫助,需要的可以參考一下2022-10-10