亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳解java代碼中init method和destroy method的三種使用方式

 更新時間:2020年03月25日 09:12:55   作者:涂宗勛  
這篇文章主要介紹了詳解java代碼中init method和destroy method的三種使用方式,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

在java的實際開發(fā)過程中,我們可能常常需要使用到init method和destroy method,比如初始化一個對象(bean)后立即初始化(加載)一些數(shù)據(jù),在銷毀一個對象之前進行垃圾回收等等。

周末對這兩個方法進行了一點學(xué)習(xí)和整理,倒也不是專門為了這兩個方法,而是在鞏固spring相關(guān)知識的時候提到了,然后感覺自己并不是很熟悉這個,便好好的了解一下。

根據(jù)特意的去了解后,發(fā)現(xiàn)實際上可以有三種方式來實現(xiàn)init method和destroy method。

要用這兩個方法,自然先要知道這兩個方法究竟是干嘛用的。而從字面意思就很容易理解,一個是加載,一個是銷毀。
下邊就正式代碼演示三種創(chuàng)建方式:

一、@Bean注解方式:

首先要創(chuàng)建一個至少擁有兩個方法的類,一個方法充當(dāng)init method,另一個充當(dāng)destroy method。

package springTest2;
public class Test1 {
  public void init() {
    System.out.println("this is init method1");
  }
  public Test1() {
    super();
    System.out.println("構(gòu)造函數(shù)1");
  }
  public void destroy() {
    System.out.println("this is destroy method1");
  }
}

這里很顯然只是一個普通的java類,擁有一個無參構(gòu)造和另外兩個方法。

需要注意的是,這里的init和destroy兩個方法名實際上是可以隨意取得,不叫這個也沒有問題,只不過算是一種約定俗稱,一般都是這樣叫。

另外我們也知道,這個構(gòu)造方法也是可以不要的,因為會隱式的自動創(chuàng)建,但是為了更清楚的看到init和destroy是什么時候執(zhí)行,我們就顯示的寫出來。

創(chuàng)建好了這個類,我們就可以使用@Bean注解的方式指定兩個方法,以讓他們生效。

package springTest2;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
@Configuration
@ComponentScan("springTest2")
public class ConfigTest {
  @Bean(initMethod = "init", destroyMethod = "destroy")
  Test1 test1() {
    return new Test1();
  }
}

這里邊的@Configguration注解是告訴spring這個類是一個配置類,相當(dāng)于我們的xml文件,@ComponentScan則是指定需要spring來掃描的包,相當(dāng)于xml中的context:component-scan屬性。

而@Bean后邊的initMethod和destroyMethod就是在聲明這是一個baen的同時指定了init和destroy方法,方法名從功能實現(xiàn)上來說可以隨意。

到這里我們就已經(jīng)用第一種方式寫好了,為了驗證成功與否,再寫一個main方法驗證一下:

package springTest2;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;
public class MainTest {
  public static void main(String[] args) {
    AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext(ConfigTest.class);
        System.out.println("#################################");
    context.close();
  }
}

運行之后結(jié)果如圖:

 

根據(jù)打印順序可以看到,首先是構(gòu)造函數(shù),也就是創(chuàng)建了bean,緊接著執(zhí)行了init,然后再context.close要銷毀bean之前又執(zhí)行了destroy。

二、JSR-250注解的方式(需要導(dǎo)入jsr250-api的jar包):

首先依然是創(chuàng)建一個擁有構(gòu)造方法在內(nèi)的三個方法的java類:

package springTest2;
import javax.annotation.PostConstruct;
import javax.annotation.PreDestroy;
public class Test2 {
  @PostConstruct
  public void init() {
    System.out.println("this is init method2");
  }
  public Test2() {
    super();
    System.out.println("構(gòu)造函數(shù)2");
  }
  @PreDestroy
  public void destroy() {
    System.out.println("this is destroy method2");
  }
}

很顯然,這里和上一個類不同的是,在init和destroy方法上加入了兩個注解,@PostConstruct和上邊@Bean后的initMethod相同,而@PreDestroy則是和destroyMethod做用相同。
既然這里有了區(qū)別,已經(jīng)指定了init method和destroy method,那么后邊聲明bean的時候自然也會有不同,也就不需要再指定一遍:

package springTest2;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
@Configuration
@ComponentScan("springTest2")
public class ConfigTest {
  @Bean
  Test2 test2() {
    return new Test2();
  }
}

所以,如上代碼中只需要簡單的聲明這是一個bean就可以了,類上邊的兩個注解和上一個例子中的意思相同。
再測試一下:

package springTest2;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;
public class MainTest {
  public static void main(String[] args) {
    AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext(ConfigTest.class);
        System.out.println("#################################");
    context.close();
  }
}

結(jié)果如下:

三、xml配置的方式:

這種方式實際上是和第一種對應(yīng)的,只不過細節(jié)上略有改變而已,首先,創(chuàng)建的java類完全一樣:

package springTest2;
public class Test3 {
  public void init() {
    System.out.println("this is init method3");
  }
  public Test3() {
    super();
    System.out.println("構(gòu)造函數(shù)3");
  }
  public void destroy() {
    System.out.println("this is destroy method3");
  }
  public void test() {
    System.out.println("testttttttt");
  }
}

不同的地方就在于,第一個例子中是使用注解告訴spring這個類相當(dāng)于一個配置文件,而這里則是實實在在的配置文件spring.xml:

<?xml version="1.0" encoding="UTF-8"?> 
<beans xmlns="http://www.springframework.org/schema/beans" 
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
  xsi:schemaLocation="http://www.springframework.org/schema/beans 
http://www.springframework.org/schema/beans/spring-beans.xsd"> 

<bean id="initOrDestroyTest" class="springTest2.Test3" init-method="init" destroy-method="destroy">
</bean>
</beans>

這個配置大概也能算是spring.xml中最簡單的一個配置了吧,除開必要的文件頭,就只有一個bean,而且bean里邊也只有id,calss和init以及destroy方法。

因為簡單,所以一目了然,id只是為了其他地方引用,class是指定這個bean對應(yīng)的類,而后邊兩個屬性則和用@Bean聲明時一模一樣。

因為這里聲明bean和指定兩個方法是用的xml配置,因此在測試的時候也就需要稍微有一點點改變:

package springTest2;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class MainTest {
  public static void main(String[] args) {
    ClassPathXmlApplicationContext context1 = new ClassPathXmlApplicationContext("spring.xml");
    System.out.println("#################################");
    context1.close();
  }
}

區(qū)別在于這里直接加載了配置文件,而不是java類,使用的是ClassPathxXmlApplicationContext而不是AnnotationConfigApplicationContext。

結(jié)果如下:

這里需要說明的一點是,在實際的web應(yīng)用使用時,可以在web.xml中使用類似下邊的配置來加載bean,實現(xiàn)init method:

<servlet-name>dispatcher</servlet-name> 
  <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> 
  <init-param> 
   <param-name>contextConfigLocation</param-name> 
   <param-value>classpath:spring.xml</param-value> 
  </init-param> 
  <load-on-startup>1</load-on-startup> 
 </servlet> 
 <servlet-mapping> 
  <servlet-name>dispatcher</servlet-name> 
  <url-pattern>/</url-pattern> 
 </servlet-mapping> 

然后啟動tomcat結(jié)果如下:

 

這里邊沒有調(diào)用destroy method,原因是spring本身代碼就需要我們手動調(diào)用銷毀bean的方法,像前邊的幾個例子中的context.close就是。

如果不手動調(diào)用這個方法,bean就不會被銷毀,也就不會去調(diào)用destroy method,這也就是為何這里在web.xml中配置后,啟動tomcat 只打印了構(gòu)造函數(shù)和init方法中的內(nèi)容。

例子都是很簡單的,而通過簡單的例子對比可能能更進一步理解相關(guān)的知識,理解了才能在實際應(yīng)用中更好的進行選擇和集成。

到此這篇關(guān)于詳解java代碼中init method和destroy method的三種使用方式的文章就介紹到這了,更多相關(guān)java中init method和destroy method內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • SpringBoot跨系統(tǒng)單點登陸的實現(xiàn)方法

    SpringBoot跨系統(tǒng)單點登陸的實現(xiàn)方法

    這篇文章主要介紹了SpringBoot跨系統(tǒng)單點登陸的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • Mybatis自定義SQL的關(guān)系映射、分頁、排序功能的實現(xiàn)

    Mybatis自定義SQL的關(guān)系映射、分頁、排序功能的實現(xiàn)

    這篇文章主要介紹了Mybatis自定義SQL的關(guān)系映射、分頁、排序功能的實現(xiàn),本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-01-01
  • Java實現(xiàn)Redis分布式鎖的三種方案匯總

    Java實現(xiàn)Redis分布式鎖的三種方案匯總

    setnx、Redisson、RedLock?都可以實現(xiàn)分布式鎖,從易到難得排序為:setnx?<?Redisson?<?RedLock,本文為大家整理了三種方法的實現(xiàn),希望對大家有所幫助
    2023-11-11
  • 關(guān)于spring?aop兩種代理混用的問題

    關(guān)于spring?aop兩種代理混用的問題

    這篇文章主要介紹了關(guān)于spring?aop兩種代理混用的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • Java8中Stream?API的peek()方法詳解及需要注意的坑

    Java8中Stream?API的peek()方法詳解及需要注意的坑

    這篇文章主要給大家介紹了關(guān)于Java8中Stream?API的peek()方法詳解及需要注意的坑,Java 中的 peek 方法是 Java 8 中的 Stream API 中的一個方法,它屬于中間操作,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2024-06-06
  • java8中Stream的使用示例教程

    java8中Stream的使用示例教程

    Stream是Java8的一大亮點,是對容器對象功能的增強,下面這篇文章主要給大家介紹了關(guān)于java8中Stream使用的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-10-10
  • Java中的線程ThreadLocal詳細解析

    Java中的線程ThreadLocal詳細解析

    這篇文章主要介紹了Java中的線程ThreadLocal詳細解析,ThreadLocal是線程本地變量,存儲在ThreadLocal里面的數(shù)據(jù)都是線程安全的,一般ThreadLocal適用的場景多是各個線程間沒有變量共享需要的同步問題場景,需要的朋友可以參考下
    2023-10-10
  • IDEA新建springboot項目時未生成pom.xml文件的解決操作

    IDEA新建springboot項目時未生成pom.xml文件的解決操作

    這篇文章主要給大家介紹了關(guān)于IDEA新建springboot項目時未生成pom.xml文件的解決操作方法,文中通過實例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2023-02-02
  • 深入理解注解與自定義注解的一些概念

    深入理解注解與自定義注解的一些概念

    今天給大家?guī)淼奈恼率亲⒔獾南嚓P(guān)知識,本文圍繞著注解與自定義注解的一些概念展開,文中詳細介紹了這些知識,需要的朋友可以參考下
    2021-06-06
  • rocketmq的AclClientRPCHook權(quán)限控制使用技巧示例詳解

    rocketmq的AclClientRPCHook權(quán)限控制使用技巧示例詳解

    這篇文章主要為大家介紹了rocketmq的AclClientRPCHook使用技巧示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-08-08

最新評論