<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    sblig

    BlogJava 首頁 新隨筆 聯系 聚合 管理
      10 Posts :: 0 Stories :: 0 Comments :: 0 Trackbacks

    2012年10月18日 #

    最后 遺留一個問題,繼續探索中....

    ?

    ?

    跟我學Spring3 學習筆記一

    跟我學Spring3 學習筆記二

    跟我學Spring3 學習筆記三

    跟我學Spring3 學習筆記四

    跟我學Spring3 學習筆記五 注入

    跟我學Spring3 學習筆記六 注入

    ?

    統一接口:

    ?

    public interface HelloApi {
    	public void sayHello();  
    }
    

    ?

    ?

    一、延遲初始化:

    ?

    /**
     * 延遲初始化Bean
     *     延遲初始化也叫做惰性初始化,指不提前初始化Bean,而是只有在真正使用時才創建及初始化Bean。
     *     配置方式很簡單只需在<bean>標簽上指定 “lazy-init” 屬性值為“true”即可延遲初始化Bean。
     */
    public class DiLazyInit implements HelloApi{
    
    	public void sayHello() {
    		System.out.println("say DiInitDestory");
    	}
    	
    	public DiLazyInit(){
    		System.out.println("初始化 DiInitDestory");
    	}
    }

    ?

    ?

    配置延遲初始化:

    ?

    ?

    <!-- 延遲初始化Bean 
    	     延遲初始化也叫做惰性初始化,指不提前初始化Bean,而是只有在真正使用時才創建及初始化Bean。
    	     配置方式很簡單只需在<bean>標簽上指定 “lazy-init” 屬性值為“true”即可延遲初始化Bean。 -->
    	<bean id="lazyinitDi" class="com.diinit.DiLazyInit"
    		lazy-init="true">
    	</bean>

    ?

    ?junit 進行測試:

    ?

    @Test
    	public void testLazyInit(){
    		ApplicationContext context = new ClassPathXmlApplicationContext("initdepends.xml");
    		HelloApi lazyInit = context.getBean("lazyinitDi",HelloApi.class);
    		lazyInit.sayHello();
    		System.out.println("");
    	}
    ?

    ?

    注意這個時候的輸出結果:

    ?

    ?

    初始化 DiLazyInit

    say DiLazyInit

    ?

    ?

    ?

    ?

    二、 可以指定初始化和銷毀的順序

    ?

    ?

    /* 使用depends-on 是指 指定Bean初始化及銷毀時的順序,使用depends-on屬性指定的Bean要先初始化完畢
    *     后才初始化當前Bean,由于只有“singleton”Bean能被Spring管理銷毀,所以當指定的Bean都是“singleton”
    *     時,使用depends-on屬性指定的Bean要在指定的Bean之后銷毀。
    *     “decorator”指定了“depends-on”屬性為“lazyinitDi”,所以在“decorator”Bean初始化之前要先初
    *     始化“lazyinitDi”,而在銷毀“lazyinitDi”之前先要銷毀“decorator”,大家注意一下銷毀順序,與文檔上的不符。
    *     “depends-on”屬性可以指定多個Bean,若指定多個Bean可以用“;”、“,”、空格分割。
    *     
    *  那“depends-on”有什么好處呢?
    *     主要是給出明確的初始化及銷毀順序,比如要初始化“decorator”時要確保“lazyinitDi”Bean的資源準備好了,
    *     否則使用“decorator”時會看不到準備的資源;而在銷毀時要先在“decorator”Bean的把對“helloApi”資源的引用釋
    *     放掉才能銷毀“lazyinitDi”,否則可能銷毀 “lazyinitDi”時而“decorator”還保持著資源訪問,造成資源不能釋放或釋放錯誤。
    */
    public class ApiDecorator implements HelloApi{
    
    	private HelloApi helloApi;
    	
    	public ApiDecorator(){
    		System.out.println("初始化 ApiDecorator");
    	}
    	
    	public void sayHello() {
    		System.out.println("say ApiDecorator");
    		helloApi.sayHello();
    		
    	}
    
    	public HelloApi getHelloApi() {
    		return helloApi;
    	}
    
    	public void setHelloApi(HelloApi helloApi) {
    		this.helloApi = helloApi;
    	}
    }
    ?

    ?

    配置xml指定初始化和銷毀順序:

    ?

    <!-- 初始化及銷毀時的順序    
    	     “decorator”指定了“depends-on”屬性為“lazyinitDi”,所以在“decorator”Bean初始化之前
    	     要先初始化“lazyinitDi”,而在銷毀“lazyinitDi”之前先要銷毀“decorator”,大家注意一下銷毀順序 -->
    	<bean id="decorator" class="com.diinit.ApiDecorator"
    		depends-on="lazyinitDi">
    		<property name="helloApi">
    			<ref bean="lazyinitDi" />
    		</property>
    	</bean>
    ?

    ?

    ?

    ?junit 進行測試:

    ?

    @Test
    	public void testLazyInit(){
    		ApplicationContext context = new ClassPathXmlApplicationContext("initdepends.xml");
    		HelloApi lazyInit = context.getBean("lazyinitDi",HelloApi.class);
    		lazyInit.sayHello();
    		System.out.println("");
    	}
    	
    	@Test
    	public void testDependsOn(){
    		ApplicationContext context= new ClassPathXmlApplicationContext("initdepends.xml");
    		HelloApi depends = context.getBean("decorator",HelloApi.class);
    		depends.sayHello();
    	}
    ?

    ?

    注意這個時候的輸出結果:

    ?

    ?

    初始化 DiLazyInit

    初始化 ApiDecorator ? ? ? ? ? ?//也是上面同樣的測試函數 testLazyInit(),同樣的配置 ?這句是多打印出來的

    say DiLazyInit

    ?

    初始化 DiLazyInit

    初始化 ApiDecorator

    say ApiDecorator

    say DiLazyInit


    ?

    ?

    ?

    這突然多出來的打印結果,說明進行了ApiDecorator的對象的創建,

    但是在第一個配置中也沒涉及到?ApiDecorator 類的加載,注入 ?。

    ?

    什么原因造成的呢?是一種隱藏的注入? 繼續探索中....

    ?

    ?



    已有 1 人發表留言,猛擊->>這里<<-參與討論


    ITeye推薦



    posted @ 2012-10-18 16:45 李凡 閱讀(168) | 評論 (0)編輯 收藏


    跟我學Spring3 學習筆記一

    跟我學Spring3 學習筆記二

    跟我學Spring3 學習筆記三

    跟我學Spring3 學習筆記四

    跟我學Spring3 學習筆記五 注入

    ?

    ?

    引用其它Bean

    ?

    一、構造器注入方式:

    (1)通過” <constructor-arg>”標簽的ref屬性來引用其他Bean

    ?

    (2)通過” <constructor-arg>”標簽的子<ref>標簽來引用其他Bean,使用bean屬性來指定引用的Bean

    二、setter注入方式:

    (1)通過” <property>”標簽的ref屬性來引用其他Bean

    (2)通過” <property>”標簽的子<ref>標簽來引用其他Bean,使用bean屬性來指定引用的Bean

    ?

    ?

    public class HelloDiBean implements HelloApi{
    
    	private HelloApi helloApi;
    	private HelloApi helloApi2;
    	
    
    	public HelloDiBean(HelloApi helloApi){
    		this.helloApi = helloApi;
    	}
    	
    	public void sayHello() {
    		helloApi.sayHello();
    		helloApi2.sayHello();
    	}
    	
    
    	public HelloApi getHelloApi2() {
    		return helloApi2;
    	}
    
    	public void setHelloApi2(HelloApi helloApi2) {
    		this.helloApi2 = helloApi2;
    	}
    }
    

    ?配置注入引用其他的bean

    ?

    <!-- 引用其他的bean進行注入 -->
    	<bean id="helloBean" class="com.dilist.HelloDiBean">
    		<constructor-arg index="0" ref="mapBean" />
    		<property name="helloApi2">
    			<ref bean="properBean" />
    		</property>
    	</bean>
    	
    ?

    其他引用bean 的高級用法:

    ?

    /**
     * Spring還提供了另外兩種更高級的配置方式,<ref local=””/>和<ref parent=””/>:
     * (1)<ref local=””/>配置方式:用于引用通過<bean id=”beanName”>方式中通過id屬性指定的Bean,
     * 		它能利用XML解析器的驗證功能在讀取配置文件時來驗證引用的Bean是否存在。
     * 		因此如果在當前配置文件中有相互引用的Bean可以采用<ref local>方式從而如果配置錯誤能在開發調試時就發現錯誤。
     * (2)<ref parent=””/>配置方式:用于引用父容器中的Bean,不會引用當前容器中的Bean,
     *       當然父容器中的Bean和當前容器的Bean是可以重名的,獲取順序是直接到父容器找。
     */
    public class HelloHigh implements HelloApi{
    	
    	private HelloApi helloApi;
    	private HelloApi helloApi2;
    	
    
    	public HelloHigh(HelloApi helloApi){
    		this.helloApi = helloApi;
    	}
    	
    	public void sayHello() {
    		helloApi.sayHello();
    		System.out.println("");
    		helloApi2.sayHello();
    	}
    	
    
    	public HelloApi getHelloApi2() {
    		return helloApi2;
    	}
    
    	public void setHelloApi2(HelloApi helloApi2) {
    		this.helloApi2 = helloApi2;
    	}
    
    }
    ?

    helloworld.xml:

    ?

    <!-- 注入properties類型 -->
    	<bean id="properBean" class="com.dilist.HelloDiProperties">
    		<property name="properties">
    			<props value-type="int" merge="default"><!-- 雖然指定value-type,但是不起作用 -->
    				<prop key="1">1sss</prop>           <!-- Properties 建和值都是String類型 -->
    				<prop key="2">2</prop>
    			</props>
    		</property>
    		<property name="properties2">
    			<value> <!-- 分隔符可以是 “換行”、“;”、“,” 不建議該方式,優先選擇第一種方式 -->
    				1=11
    				2=22;<!-- 這樣的分隔符好像沒用 -->
    			    3=33,
    				4=44
    			</value>
    		</property>
    	</bean>
    
    	<!-- Spring還提供了另外兩種更高級的配置方式,<ref local=””/>和<ref parent=””/> -->
    	<bean id="helloHigh" class="com.dilist.HelloHigh">
    		<constructor-arg index="0"><ref local="properBean" /></constructor-arg>
    		<property name="helloApi2"><ref parent="properBean" /></property>	
    	</bean>
    ?

    ?

    helloworldParent.xml:

    ?

    <!-- 注入properties類型 -->
    	<bean id="properBean" class="com.dilist.HelloDiProperties">
    		<property name="properties">
    			<props value-type="int" merge="default"><!-- 雖然指定value-type,但是不起作用 -->
    				<prop key="1">2dss</prop>           <!-- Properties 建和值都是String類型 -->
    				<prop key="2">3aas</prop>
    			</props>
    		</property>
    		<property name="properties2">
    			<value> <!-- 分隔符可以是 “換行”、“;”、“,” 不建議該方式,優先選擇第一種方式 -->
    				1=111
    				2=222;<!-- 這樣的分隔符好像沒用 -->
    			    3=333,
    				4=444
    			</value>
    		</property>
    	</bean>
    ?

    調用處 利用加載父容器的方式,注入父容器中的Bean:

    ?

    ?

    @Test
    	public void testDiBeanHigh() {
    		// 以classes為根目錄算起
    		// 讀取配置文件實例化一個Ioc容器
    
    		// 初始化父容器
    		ApplicationContext parentContext = new ClassPathXmlApplicationContext(
    				"helloworldParent.xml");
    
    		// 初始化當前容器
    		ApplicationContext context = new ClassPathXmlApplicationContext(
    				new String[] { "helloworld.xml" }, parentContext);
    
    		// 構造 + setter注入 引用其他的bean注入
    		HelloApi helloApi = context.getBean("helloHigh", HelloApi.class);
    		helloApi.sayHello();
    
    	}


    已有 0 人發表留言,猛擊->>這里<<-參與討論


    ITeye推薦



    posted @ 2012-10-18 14:32 李凡 閱讀(152) | 評論 (0)編輯 收藏

    主站蜘蛛池模板: 久久久久久精品成人免费图片| 波多野结衣在线免费视频| a毛片视频免费观看影院| 国产亚洲综合一区柠檬导航| 亚洲国产成人久久综合| 国产精品国产午夜免费福利看| 曰批免费视频播放免费| 亚洲AV无码码潮喷在线观看| 午夜宅男在线永久免费观看网| 色费女人18女人毛片免费视频| 成人免费视频网址| 亚洲色欲色欱wwW在线| 中文字幕亚洲综合久久菠萝蜜| ww4545四虎永久免费地址| 亚洲第一成年免费网站| 久热综合在线亚洲精品| 国产免费黄色大片| 美女内射毛片在线看免费人动物| 真人无码作爱免费视频| 亚洲精品视频在线播放| 亚洲精品视频在线看| 黄色短视频免费看| 国产AV无码专区亚洲AV手机麻豆 | 特级做A爰片毛片免费69 | 成人免费在线观看网站| 怡红院免费的全部视频| 亚洲精品国产摄像头| 91亚洲精品第一综合不卡播放| 亚洲AV无码一区二区三区国产| av无码免费一区二区三区| 日本免费A级毛一片| 色噜噜狠狠色综合免费视频 | 亚洲成a人无码亚洲成www牛牛| 亚洲a一级免费视频| 亚洲一区二区三区免费在线观看| 一级成人毛片免费观看| 亚洲AV无码专区国产乱码不卡| 亚洲影视一区二区| 久久久久久久久亚洲| 中文字幕在线亚洲精品| 亚洲福利在线播放|