久久96国产精品久久久-久久发布国产伦子伦精品-久久精品国产精品青草-久久天天躁夜夜躁狠狠85麻豆

技術員聯盟提供win764位系統下載,win10,win7,xp,裝機純凈版,64位旗艦版,綠色軟件,免費軟件下載基地!

當前位置:主頁 > 教程 > 服務器類 >

spring之Bean的生命周期教程

來源:技術員聯盟┆發布時間:2017-10-27 00:56┆點擊:

  Bean的生命周期:

  Bean的定義——Bean的初始化——Bean的使用——Bean的銷毀

  Bean的定義

  Bean 是 spring 裝配的組件模型,一切實體類都可以配置成一個 Bean ,進而就可以在任何其他的 Bean 中使用,一個 Bean 也可以不是指定的實體類,這就是抽象 Bean 。

  Bean的初始化

  Spring中bean的初始化回調有兩種方法

  一種是在配置文件中聲明init-method="init",然后在一個實體類中用init()方法來初始化

  另一種是實現InitializingBean接口,覆蓋afterPropertiesSet()方法。

  第一種:

  配置文件:

  

  

  xmlns=""

  xmlns:xsi=""

  xmlns:p=""

  xsi:schemaLocation="

  ">

  

  

  

  BeanInitDemo1類:

  package org.spring.test;

  public class BeanInitDemo1 {

  private String message;

  public String getMessage() {

  return message;

  }

  public void setMessage(String message) {

  this.message = message;

  }

  public void init(){

  this.setMessage("這里是init()方法初始化設值");

  }

  }

  測試類:

  package org.spring.test;

  import org.springframework.context.ApplicationContext;

  import org.springframework.context.support.ClassPathXmlApplicationContext;

  public class Test {

  public static void main(String[] args) {

  ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");

  BeanInitDemo1 bid = (BeanInitDemo1) context.getBean("init-one");

  System.out.println(bid.getMessage());

  }

  }

  運行結果:

  這里是init()方法初始化設值

  原因:init()初始化方法的調用是在配置文件的Bean初始化之后執行的, 所以改變了配置文件中對message的賦值。

  第二種:

  配置文件:

  

  

  xmlns=""

  xmlns:xsi=""

  xmlns:p=""

  xsi:schemaLocation="

  ">

  

  

  

  編寫BeanInitDemo2類,使其實現InitializingBean接口

  package org.spring.test;

  import org.springframework.beans.factory.InitializingBean;

  public class BeanInitDemo2 implements InitializingBean{

  private String message;

  public String getMessage() {

  return message;

  }

  public void setMessage(String message) {

  this.message = message;

  }

  public void afterPropertiesSet() throws Exception {

  // TODO Auto-generated method stub

  this.setMessage("這里覆蓋了InitializingBean接口的afterPropertiesSet()方法設值");

  }

  }

  測試:

  package org.spring.test;

  import org.springframework.context.ApplicationContext;

  import org.springframework.context.support.ClassPathXmlApplicationContext;

  public class Test {

  public static void main(String[] args) {

  ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");

  BeanInitDemo2 bid = (BeanInitDemo2) context.getBean("init-two");

  System.out.println(bid.getMessage());

  }

  }

  運行結果: 這里覆蓋了InitializingBean接口的afterPropertiesSet()方法設值

  原因相同,afterPropertiesSet()方法在配置文件的Bean初始化后執行,所以改變了配置文件中對message的賦值

  Bean的使用

  Spring中有兩種使用bean的方法:

  1, BeanFactory:

  BeanFactory factory= new XmlBeanFactory(new ClassPathResource("bean.xml"));

  factory.getBean("student");

  BeanFactory是延遲加載,如果Bean的某一個屬性沒有注入,BeanFacotry加載后,直至第一次使用getBean方法才會拋出異常,也就是說當使用BeanFactory實例化對象時,配置的bean不會馬上被實例化。當你使用該bean時才會被實例化(getBean)。

  2, ApplicationContext:

  ApplicationContext ac = new ClassPathXmlApplicationContext("bean.xml");

  如果使用ApplicationContext,則配置的bean如果是singleton不管你用還是不用,都被實例化。ApplicationContext在初始化自身時檢驗,這樣有利于檢查所依賴屬性是否注入。ApplicationContext是BeanFactory的子類,除了具有BeanFactory的所有功能外還提供了更完整的框架功能,例如國際化,資源訪問等。所以通常情況下我們選擇使用ApplicationContext。

  Bean的銷毀

  Bean的銷毀和初始化一樣,都是提供了兩個方法

  一是在配置文件中聲明destroy-method="cleanup",然后在類中寫一個cleanup()方法銷毀

  二是實現DisposableBean接口,覆蓋destory()方法

  第一種:

  配置文件:

  

  

  xmlns=""

  xmlns:xsi=""

  xmlns:p=""

  xsi:schemaLocation="

  ">

  

  

  

  BeanDestoryDemo1類:

  package org.spring.test;

  public class BeanDestoryDemo1 {

  private String message;

  public String getMessage() {

  return message;

  }

  public void setMessage(String message) {

  this.message = message;

  }

  public void cleanup(){

  System.out.println("銷毀之前可以調用一些方法");

  }

  }

  測試:

  package org.spring.test;

  import org.springframework.context.support.AbstractApplicationContext;

  import org.springframework.context.support.ClassPathXmlApplicationContext;

  public class DestortTest {

  public static void main(String[] args) {

  AbstractApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");

  BeanDestoryDemo1 bdd = (BeanDestoryDemo1) context.getBean("destory-one");

  System.out.println(bdd.getMessage());

  context.registerShutdownHook();

  }

  }

  運行結果:

spring之Bean的生命周期教程

  context.registerShutdownHook()是為spring注冊關閉吊鉤,程序退出之前關閉spring容器,如果沒有

  context.registerShutdownHook();將不會執行cleanup()方法。

  第二種:

  配置文件:

  

  

  xmlns=""

  xmlns:xsi=""

  xmlns:p=""

  xsi:schemaLocation="

  ">

  

  

  

  BeanDestoryDemo2類:

  package org.spring.test;

  import org.springframework.beans.factory.DisposableBean;

  public class BeanDestoryDemo2 implements DisposableBean{

  private String message;

  public String getMessage() {

  return message;

  }

  public void setMessage(String message) {

  this.message = message;

  }

  public void destroy() throws Exception {

  // TODO Auto-generated method stub

  System.out.println("同樣,銷毀之前調用的方法");

  }

  }

  測試:

  package org.spring.test;

  import org.springframework.context.support.AbstractApplicationContext;

  import org.springframework.context.support.ClassPathXmlApplicationContext;

  public class DestortTest {

  public static void main(String[] args) {

  AbstractApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");

  BeanDestoryDemo2 bdd = (BeanDestoryDemo2) context.getBean("destory-two");

  System.out.println(bdd.getMessage());

  context.registerShutdownHook();

  }

  }

  運行結果:

spring之Bean的生命周期教程

  Spring可以管理singleton作用域的Bean的生命周期,所以在Bean初始化及銷毀之前可以做一些工作,更靈活的管理Bean。