關于接口ApplicationContext中的getBean()方法使用_第1頁
關于接口ApplicationContext中的getBean()方法使用_第2頁
關于接口ApplicationContext中的getBean()方法使用_第3頁
關于接口ApplicationContext中的getBean()方法使用_第4頁
關于接口ApplicationContext中的getBean()方法使用_第5頁
已閱讀5頁,還剩1頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

第關于接口ApplicationContext中的getBean()方法使用目錄getBean一共有以下四種方法原型第一種:lgetBean(Stringname)第二種:lgetBean(ClassTtype)第三種:lgetBean(Stringname,ClassTtype)第四種:lgetBean(Stringname,Object[]args)我們知道可以通過ApplicationContext的getBean方法來獲取Spring容器中已初始化的bean。

getBean一共有以下四種方法原型

1,lgetBean(Stringname)2,lgetBean(ClassTtype)3,lgetBean(Stringname,ClassTtype)4,lgetBean(Stringname,Object[]args)

下來我們分別來探討以上四種方式獲取bean的區(qū)別。

其中實體類Person定義如下:

publicclassPerson{

privateStringname;

privateintage;

publicPerson(){}

publicPerson(Stringname,intage){

=name;

this.age=age;

publicStringgetName(){

returnname;

publicvoidsetName(Stringname){

=name;

publicintgetAge(){

returnage;

publicvoidsetAge(intage){

this.age=age;

@Override

publicStringtoString(){

return"Person[name="+name+",age="+age+"]";

}

applicationContext.xml注冊有id為p的bean,配置如下:

beanid="p"

propertyname="name"value="張三"/

propertyname="age"value="18"/

/bean

第一種:lgetBean(Stringname)

參數name表示IOC容器中已經實例化的bean的id或者name,且無論是id還是name都要求在IOC容器中是唯一的不能重名。

那么這種方法就是通過id或name去查找獲取bean.獲取bean的參考代碼如下:

@Test

publicvoidtestPerson()

ApplicationContextctx=newClassPathXmlApplicationContext("applicationContext.xml");

Personp=(Person)ctx.getBean("p");

System.out.println(p);

}

第二種:lgetBean(ClassTtype)

參數ClassTtype表示要加載的Bean的類型。

如果該類型沒有繼承任何父類(Object類除外)和實現接口的話,那么要求該類型的bean在IOC容器中也必須是唯一的。

比如applicationContext.xml配置兩個類型完全一致的bean,且都沒有配置id和name屬性。

bean

propertyname="name"value="張三"/

propertyname="age"value="18"/

/bean

bean

propertyname="name"value="李四"/

propertyname="age"value="20"/

/bean

那么通過com.bean.Person這種類型來查找bean,參考代碼如下:

@Test

publicvoidtestPerson()

ApplicationContextctx=newClassPathXmlApplicationContext("applicationContext.xml");

Personp=ctx.getBean(Person.class);

System.out.println(p);

}

但是由于屬于com.bean.Person的bean在IOC容器中不唯一,所以這里會拋出NoUniqueBeanDefinitionException異常。

由此我們可以總結getBean(Stringname)和getBean(ClassTtype)的異同點。

相同點:都要求id或者name或者類型在容器中的唯一性。不同點:getBean(Stringname)獲得的對象需要類型轉換而getBean(ClassTtype)獲得的對象無需類型轉換。

第三種:lgetBean(Stringname,ClassTtype)

這種方式比較適合當類型不唯一時,再通過id或者name來獲取bean。

例如applicationContext.xml配置有如下bean:

beanid="p1"

propertyname="name"value="張三"/

propertyname="age"value="18"/

/bean

beanname="p2"

propertyname="name"value="李四"/

propertyname="age"value="20"/

/bean

參考代碼如下:

@Test

publicvoidtestPerson()

ApplicationContextctx=newClassPathXmlApplicationContext("applicationContext.xml");

Personp=ctx.getBean("p2",Person.class);

System.out.println(p);

}

這樣可以獲取到名字叫李四的對象。

第四種:lgetBean(Stringname,Object[]args)

這種方式本質還是通過bean的id或者name來獲取bean,通過第二個參數Object[]args可以給bean的屬性賦值,賦值的方式有兩種:構造方法和工廠方法。

但是通過這種方式獲取的bean必須把scope屬性設置為prototype,也就是非單例模式。

先在com.factory包下設計有如下的工廠類:

publicclassPersonFactory{

//靜態(tài)工廠注入

publicstaticPersongetPersonInstance(Stringname,intage)throwsException

Personp=(Person)Class.forName("com.bean.Person").newInstance();

Methodm=p.getClass().getMethod("setName",java.lang.String.class);

m.invoke(p,name);

m=p.getClass().getMethod("setAge",int.class);

m.invoke(p,age);

returnp;

}

在applicationContext.xml中配置有如下bean:

beanname="p3"scope="prototype"/

獲取bean的參考代碼如下:

@Test

publicvoidtestPerson()

ApplicationContextctx=newClassPathXmlApplicationContext("applicationContext.xml");

Personp=(Person)ctx.getBean("p3",newObject[]{"王五",35});

System.out.println(p);

}

如果想通過工廠注入屬性,在applicationContext.xml配置如下bean:

beanname="p3"factory-met

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論