亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

Spring Bean的生命周期

2019-11-14 10:27:40
字體:
來源:轉載
供稿:網友

sPRing作為當前java最流行、最強大的輕量級框架,受到了程序員的熱烈歡迎。準確的了解Spring Bean的生命周期是非常必要的。我們通常使用applicationContext作為Spring容器。這里,我們講的也是 ApplicationContext中Bean的生命周期。而實際上BeanFactory也是差不多的,只不過處理器需要手動注冊。

 ,謝謝。

一、生命周期流程圖:

  Spring Bean的完整生命周期從創建Spring容器開始,直到最終Spring容器銷毀Bean,這其中包含了一系列關鍵點。

 

若容器注冊了以上各種接口,程序那么將會按照以上的流程進行。下面將仔細講解各接口作用。

 

二、各種接口方法分類

Bean的完整生命周期經歷了各種方法調用,這些方法可以劃分為以下幾類:

1、Bean自身的方法 ?。骸 ∵@個包括了Bean本身調用的方法和通過配置文件中<bean>的init-method和destroy-method指定的方法

2、Bean級生命周期接口方法  :  這個包括了BeanNameAware、BeanFactoryAware、InitializingBean和DiposableBean這些接口的方法

3、容器級生命周期接口方法 ?。骸 ∵@個包括了InstantiationAwareBeanPostProcessor 和 BeanPostProcessor 這兩個接口實現,一般稱它們的實現類為“后處理器”。

4、工廠后處理器接口方法 ?。骸 ∵@個包括了BeanFactoryPostProcessor等等非常有用的工廠后處理器接口的方法。工廠后處理器也是容器級的。在應用上下文裝配配置文件之后立即調用。

  

三、演示

我們用一個簡單的Spring Bean來演示一下Spring Bean的生命周期。

1、首先是一個簡單的Spring Bean,調用Bean自身的方法和Bean級生命周期接口方法,為了方便演示,它實現了BeanNameAware、BeanFactoryAware、InitializingBean和DiposableBean這4個接口,同時有2個方法,對應配置文件中<bean>的init-method和destroy-method。如下:

[java] view plain copy print?<span style="font-family:SimSun;font-size:14px;">package springBeanTest;    import org.springframework.beans.BeansException;  import org.springframework.beans.factory.BeanFactory;  import org.springframework.beans.factory.BeanFactoryAware;  import org.springframework.beans.factory.BeanNameAware;  import org.springframework.beans.factory.DisposableBean;  import org.springframework.beans.factory.InitializingBean;    /**  * @author qsk  */  public class Person implements BeanFactoryAware, BeanNameAware,          InitializingBean, DisposableBean {        private String name;      private String address;      private int phone;        private BeanFactory beanFactory;      private String beanName;        public Person() {          System.out.println("【構造器】調用Person的構造器實例化");      }        public String getName() {          return name;      }        public void setName(String name) {          System.out.println("【注入屬性】注入屬性name");          this.name = name;      }        public String getAddress() {          return address;      }        public void setAddress(String address) {          System.out.println("【注入屬性】注入屬性address");          this.address = address;      }        public int getPhone() {          return phone;      }        public void setPhone(int phone) {          System.out.println("【注入屬性】注入屬性phone");          this.phone = phone;      }        @Override      public String toString() {          return "Person [address=" + address + ", name=" + name + ", phone="                  + phone + "]";      }        // 這是BeanFactoryAware接口方法      @Override      public void setBeanFactory(BeanFactory arg0) throws BeansException {          System.out                  .println("【BeanFactoryAware接口】調用BeanFactoryAware.setBeanFactory()");          this.beanFactory = arg0;      }        // 這是BeanNameAware接口方法      @Override      public void setBeanName(String arg0) {          System.out.println("【BeanNameAware接口】調用BeanNameAware.setBeanName()");          this.beanName = arg0;      }        // 這是InitializingBean接口方法      @Override      public void afterPropertiesSet() throws Exception {          System.out                  .println("【InitializingBean接口】調用InitializingBean.afterPropertiesSet()");      }        // 這是DiposibleBean接口方法      @Override      public void destroy() throws Exception {          System.out.println("【DiposibleBean接口】調用DiposibleBean.destory()");      }        // 通過<bean>的init-method屬性指定的初始化方法      public void myInit() {          System.out.println("【init-method】調用<bean>的init-method屬性指定的初始化方法");      }        // 通過<bean>的destroy-method屬性指定的初始化方法      public void myDestory() {          System.out.println("【destroy-method】調用<bean>的destroy-method屬性指定的初始化方法");      }  }</span>  

2、接下來是演示BeanPostProcessor接口的方法,如下:

[java] view plain copy print?<span style="font-family:SimSun;font-size:14px;">package springBeanTest;    import org.springframework.beans.BeansException;  import org.springframework.beans.factory.config.BeanPostProcessor;    public class MyBeanPostProcessor implements BeanPostProcessor {        public MyBeanPostProcessor() {          super();          System.out.println("這是BeanPostProcessor實現類構造器??!");          // TODO Auto-generated constructor stub      }        @Override      public Object postProcessAfterInitialization(Object arg0, String arg1)              throws BeansException {          System.out                  .println("BeanPostProcessor接口方法postProcessAfterInitialization對屬性進行更改!");          return arg0;      }        @Override      public Object postProcessBeforeInitialization(Object arg0, String arg1)              throws BeansException {          System.out                  .println("BeanPostProcessor接口方法postProcessBeforeInitialization對屬性進行更改!");          return arg0;      }  }</span>  

如上,BeanPostProcessor接口包括2個方法postProcessAfterInitialization和postProcessBeforeInitialization,這兩個方法的第一個參數都是要處理的Bean對象,第二個參數都是Bean的name。返回值也都是要處理的Bean對象。這里要注意。

 

3、InstantiationAwareBeanPostProcessor接口本質是BeanPostProcessor的子接口,一般我們繼承Spring為其提供的適配器類InstantiationAwareBeanPostProcessorAdapter來使用它,如下:

[java] view plain copy print?<span style="font-family:SimSun;font-size:14px;">package springBeanTest;    import java.beans.PropertyDescriptor;    import org.springframework.beans.BeansException;  import org.springframework.beans.PropertyValues;  import org.springframework.beans.factory.config.InstantiationAwareBeanPostProcessorAdapter;    public class MyInstantiationAwareBeanPostProcessor extends          InstantiationAwareBeanPostProcessorAdapter {      public MyInstantiationAwareBeanPostProcessor() {          super();          System.out                  .println("這是InstantiationAwareBeanPostProcessorAdapter實現類構造器??!");      }        // 接口方法、實例化Bean之前調用      @Override      public Object postProcessBeforeInstantiation(Class beanClass,              String beanName) throws BeansException {          System.out                  .println("InstantiationAwareBeanPostProcessor調用postProcessBeforeInstantiation方法");          return null;      }        // 接口方法、實例化Bean之后調用      @Override      public Object postProcessAfterInitialization(Object bean, String beanName)              throws BeansException {          System.out                  .println("InstantiationAwareBeanPostProcessor調用postProcessAfterInitialization方法");          return bean;      }        // 接口方法、設置某個屬性時調用      @Override      public PropertyValues postProcessPropertyValues(PropertyValues pvs,              PropertyDescriptor[] pds, Object bean, String beanName)              throws BeansException {          System.out                  .println("InstantiationAwareBeanPostProcessor調用postProcessPropertyValues方法");          return pvs;      }  }</span>  

這個有3個方法,其中第二個方法postProcessAfterInitialization就是重寫了BeanPostProcessor的方法。第三個方法postProcessPropertyValues用來操作屬性,返回值也應該是PropertyValues對象。

 

4、演示工廠后處理器接口方法,如下:

[java] view plain copy print?<span style="font-family:SimSun;font-size:14px;">package springBeanTest;    import org.springframework.beans.BeansException;  import org.springframework.beans.factory.config.BeanDefinition;  import org.springframework.beans.factory.config.BeanFactoryPostProcessor;  import org.springframework.beans.factory.config.ConfigurableListableBeanFactory;    public class MyBeanFactoryPostProcessor implements BeanFactoryPostProcessor {        public MyBeanFactoryPostProcessor() {          super();          System.out.println("這是BeanFactoryPostProcessor實現類構造器??!");      }        @Override      public void postProcessBeanFactory(ConfigurableListableBeanFactory arg0)              throws BeansException {          System.out                  .println("BeanFactoryPostProcessor調用postProcessBeanFactory方法");          BeanDefinition bd = arg0.getBeanDefinition("person");          bd.getPropertyValues().addPropertyValue("phone", "110");      }    }</span>  

 

5、配置文件如下beans.xml,很簡單,使用ApplicationContext,處理器不用手動注冊:

[html] view plain copy print?<span style="font-family:SimSun;font-size:14px;"><?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:p="http://www.springframework.org/schema/p"      xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx"      xsi:schemaLocation="              http://www.springframework.org/schema/beans               http://www.springframework.org/schema/beans/spring-beans-3.2.xsd">        <bean id="beanPostProcessor" class="springBeanTest.MyBeanPostProcessor">      </bean>        <bean id="instantiationAwareBeanPostProcessor" class="springBeanTest.MyInstantiationAwareBeanPostProcessor">      </bean>        <bean id="beanFactoryPostProcessor" class="springBeanTest.MyBeanFactoryPostProcessor">      </bean>            <bean id="person" class="springBeanTest.Person" init-method="myInit"          destroy-method="myDestory" scope="singleton" p:name="張三" p:address="廣州"          p:phone="15900000000" />    </beans></span>  

6、下面測試一下:

[java] view plain copy print?<span style="font-family:SimSun;font-size:14px;">package springBeanTest;    import org.springframework.context.ApplicationContext;  import org.springframework.context.support.ClassPathXmlApplicationContext;    public class BeanLifeCycle {        public static void main(String[] args) {            System.out.println("現在開始初始化容器");            ApplicationContext factory = new ClassPathXmlApplicationContext(                  "springBeanTest/beans.xml");          System.out.println("容器初始化成功");          // 得到Preson,并使用          Person person = factory.getBean("person", Person.class);          System.out.println(person);            System.out.println("現在開始關閉容器!");          ((ClassPathXmlApplicationContext) factory).registerShutdownHook();      }  }</span>  

關閉容器使用的是實際是AbstractApplicationContext的鉤子方法。

我們來看一下結果:

現在開始初始化容器2014-5-18 15:46:20 org.springframework.context.support.AbstractApplicationContext prepareRefresh信息: Refreshing org.springframework.context.support.ClassPathXmlApplicationContext@19a0c7c: startup date [Sun May 18 15:46:20 CST 2014]; root of context hierarchy2014-5-18 15:46:20 org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions信息: Loading XML bean definitions from class path resource [springBeanTest/beans.xml]這是BeanFactoryPostProcessor實現類構造器!!BeanFactoryPostProcessor調用postProcessBeanFactory方法這是BeanPostProcessor實現類構造器??!這是InstantiationAwareBeanPostProcessorAdapter實現類構造器??!2014-5-18 15:46:20 org.springframework.beans.factory.support.DefaultListableBeanFactory preInstantiateSingletons信息: Pre-instantiating singletons in org.springframework.beans.factory.support.DefaultListableBeanFactory@9934d4: defining beans [beanPostProcessor,instantiationAwareBeanPostProcessor,beanFactoryPostProcessor,person]; root of factory hierarchyInstantiationAwareBeanPostProcessor調用postProcessBeforeInstantiation方法【構造器】調用Person的構造器實例化InstantiationAwareBeanPostProcessor調用postProcessPropertyValues方法【注入屬性】注入屬性address【注入屬性】注入屬性name【注入屬性】注入屬性phone【BeanNameAware接口】調用BeanNameAware.setBeanName()【BeanFactoryAware接口】調用BeanFactoryAware.setBeanFactory()BeanPostProcessor接口方法postProcessBeforeInitialization對屬性進行更改!【InitializingBean接口】調用InitializingBean.afterPropertiesSet()【init-method】調用<bean>的init-method屬性指定的初始化方法BeanPostProcessor接口方法postProcessAfterInitialization對屬性進行更改!InstantiationAwareBeanPostProcessor調用postProcessAfterInitialization方法容器初始化成功Person [address=廣州, name=張三, phone=110]現在開始關閉容器!【DiposibleBean接口】調用DiposibleBean.destory()【destroy-method】調用<bean>的destroy-method屬性指定的初始化方法

 

/***   ————————如果覺得本博文還行,別忘了推薦一下哦,謝謝!*   作者:錢書康*   歡迎轉載,請保留此段聲明。*   出處:http://www.49028c.com/zrtqsk/ */


上一篇:c#內存分配

下一篇:Xdebug -- Xampp安裝

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久精品视频在线| 久久久久久亚洲精品不卡| 激情av一区二区| 欧美日韩美女在线观看| 日韩电影中文字幕一区| 欧亚精品中文字幕| 国产91热爆ts人妖在线| 国产剧情久久久久久| 一本色道久久88综合日韩精品| 国产极品jizzhd欧美| 日韩美女av在线免费观看| 国产精品电影观看| 中文字幕精品www乱入免费视频| 久久久国产视频91| 日本老师69xxx| 在线视频欧美性高潮| 亚洲视频自拍偷拍| 日韩视频免费大全中文字幕| 亚洲精品色婷婷福利天堂| 日韩av中文在线| 国语自产在线不卡| 欧美一区深夜视频| 成人女保姆的销魂服务| 精品国产乱码久久久久酒店| 亚洲欧洲午夜一线一品| 久久色精品视频| 日韩国产精品一区| 日韩免费在线观看视频| 日韩国产精品一区| 亚洲精品福利免费在线观看| 亚洲第一网中文字幕| 久久久久久久999| 亚洲精品456在线播放狼人| 91久久国产综合久久91精品网站| 亚洲理论电影网| 欧美性生交大片免费| 亚洲欧洲日产国产网站| 久久乐国产精品| 国产精品视频久久久久| 欧美在线一区二区视频| 日本精品久久中文字幕佐佐木| 亚洲人成电影网站色…| 亚洲电影免费观看高清完整版在线| 久久综合色88| 中文字幕久久亚洲| 精品久久久久久久久中文字幕| 国产一区二区香蕉| 欧美成人精品一区二区三区| 日本午夜在线亚洲.国产| 国产精品视频自在线| 久久精品国产亚洲一区二区| 国产精品99久久久久久久久久久久| 欧美午夜精品久久久久久人妖| 色综合影院在线| 国产精品爽爽ⅴa在线观看| 欧美激情视频网址| 亚洲视频国产视频| 日韩视频第一页| 欧美大片免费观看| 91在线国产电影| 久久不射热爱视频精品| 欧美精品九九久久| 午夜精品视频网站| 97国产在线观看| 亚洲aaaaaa| 亚洲嫩模很污视频| 波霸ol色综合久久| 日本精品一区二区三区在线播放视频| 欧美丰满少妇xxxxx做受| 欧美一区二区三区精品电影| 成人信息集中地欧美| 亚洲缚视频在线观看| 久久精品一本久久99精品| 欧美黑人xxxⅹ高潮交| 成人福利在线视频| 92国产精品久久久久首页| 成年人精品视频| 日韩欧美精品网址| 亚洲bt欧美bt日本bt| 国产在线拍偷自揄拍精品| 精品久久久国产精品999| 精品久久久久久久久久| 欧美中文字幕第一页| 国产亚洲精品一区二区| 国内精品久久久久影院优| 精品国产欧美一区二区三区成人| 欧美在线视频一二三| 亚洲免费视频在线观看| 成人写真福利网| 久久国产精品久久久| 亚洲欧美中文在线视频| 久久久精品国产| 久久视频在线视频| 91国内揄拍国内精品对白| 成人黄色片网站| 久久久久久美女| 亚洲国产精品女人久久久| 亚洲大胆美女视频| 日本精品久久久久久久| 国产99视频精品免视看7| 亚洲97在线观看| 日韩精品在线私人| 国产精品看片资源| 国产成人精品一区二区在线| 在线视频免费一区二区| 乱亲女秽乱长久久久| 欧美亚州一区二区三区| 韩剧1988在线观看免费完整版| 91久久久久久久久久| 亚洲理论片在线观看| 久久精品视频一| 亚洲va久久久噜噜噜久久天堂| 国产精品成人一区二区| 日韩中文字幕国产精品| 亚洲一区二区三区毛片| 久久av在线看| 国产激情综合五月久久| 久久欧美在线电影| 国产一区二区三区高清在线观看| 26uuu国产精品视频| 欧美成人精品激情在线观看| 欧美激情一区二区三区久久久| 欧美极品少妇全裸体| 久久久久久有精品国产| 国产精品美女网站| 国产91九色视频| 亚洲天堂av高清| 成人免费xxxxx在线观看| 91av在线免费观看视频| 国产经典一区二区| 欧美日韩色婷婷| 久久影院模特热| 日韩成人在线网站| 欧美国产精品人人做人人爱| 奇米4444一区二区三区| 国产亚洲视频中文字幕视频| 午夜精品视频网站| 日韩在线视频播放| 亚洲精品视频播放| 日韩视频中文字幕| 亚州国产精品久久久| 97超碰色婷婷| 亚洲欧美日韩爽爽影院| 久久久免费精品视频| 亚洲一区二区黄| 97精品久久久| 欧美高清视频免费观看| 97热精品视频官网| 影音先锋欧美在线资源| 久久亚洲影音av资源网| 亚洲黄色av女优在线观看| 欧美疯狂xxxx大交乱88av| 成人444kkkk在线观看| 亚洲视频777| 欧美视频中文在线看| 国产色综合天天综合网| 精品国产91久久久久久老师| 一区二区欧美激情| 九色精品美女在线| 国产成人av在线| 亚洲第一精品久久忘忧草社区| 91人人爽人人爽人人精88v| 热99精品只有里视频精品| 1769国产精品|