Spring還支持基於JSR-250的注解,其中包括@PostConstruct,@PreDestroy和@Resource注解。雖然這些注解不是真正需要的,因為你已經有其他替代品,但讓我們簡要了解一下。
@PostConstruct和@PreDestroy注解
要定義一個bean的設置和拆卸,我們只需使用init-method和/或destroy-method參數聲明<bean> 。init-method屬性指定一個在實例化后立即在bean上調用的方法。類似地,destroy-method指定在bean從容器中刪除之前調用的方法。
在這里你可以使用@PostConstruct注解作為初始化回調和@PreDestroy注解的替代,作為銷毀回調的替代。
例子:
pom.xml:
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>com.jsoft.testspring</groupId> <artifactId>testannotationjsr250</artifactId> <version>0.0.1-SNAPSHOT</version> <packaging>jar</packaging> <name>testannotationjsr250</name> <url>http://maven.apache.org</url> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> </properties> <dependencies> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>3.8.1</version> <scope>test</scope> </dependency> <!-- Spring Core --> <!-- http://mvnrepository.com/artifact/org.springframework/spring-core --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-core</artifactId> <version>4.1.4.RELEASE</version> </dependency> <!-- Spring Context --> <!-- http://mvnrepository.com/artifact/org.springframework/spring-context --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>4.1.4.RELEASE</version> </dependency> </dependencies> </project>
HelloWorld.java:
package com.jsoft.testspring.testannotationjsr250; import javax.annotation.PostConstruct; import javax.annotation.PreDestroy; public class HelloWorld { private String messageString; public void setMessage(String message){ this.messageString = message; } public void getMessage(){ System.out.println(this.messageString); } @PostConstruct public void initPost(){ System.out.println("@ init"); } @PreDestroy public void destroyPre(){ System.out.println("@ destroy"); } }
beans.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" xmlns:context="http://www.springframework.org/schema/context" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd"> <bean id="helloWorld" class="com.jsoft.testspring.testannotationjsr250.HelloWorld"> <property name="Message" value="Hello World!"></property> </bean> <context:annotation-config/> </beans>
App.java:
package com.jsoft.testspring.testannotationjsr250; import org.springframework.context.support.AbstractApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; /** * Hello world! * */ public class App { public static void main( String[] args ) { AbstractApplicationContext abstractApplicationContext = new ClassPathXmlApplicationContext("beans.xml"); HelloWorld helloWorld = (HelloWorld)abstractApplicationContext.getBean("helloWorld"); helloWorld.getMessage(); abstractApplicationContext.registerShutdownHook();//因為在AbstractApplicationContext類中才有registerShutdownHook()方法 } }
測試結果:
@Resource注釋
你可以對字段或setter方法使用@Resource注釋,它與Java EE 5中的工作方式相同。@Resource注釋采用“name”屬性,將被解釋為要注入的bean名稱。
如果沒有明確指定“name”,則默認名稱是從字段名稱或setter方法派生的。在一個字段的情況下,它需要字段名稱,在setter方法的情況下,它將使用bean屬性名稱。
例子:
HelloWorld.java:
package com.jsoft.testspring.testannotationjsr250; import javax.annotation.PostConstruct; import javax.annotation.PreDestroy; import javax.annotation.Resource; public class HelloWorld { private String messageString; @Resource(name="msg") public void setMessage(String message){ this.messageString = message; } public void getMessage(){ System.out.println(this.messageString); } @PostConstruct public void initPost(){ System.out.println("@ init"); } @PreDestroy public void destroyPre(){ System.out.println("@ destroy"); } }
beans.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" xmlns:context="http://www.springframework.org/schema/context" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd"> <bean id="msg" class="java.lang.String"> <constructor-arg index="0" value="Hello World!"></constructor-arg> </bean> <bean id="helloWorld" class="com.jsoft.testspring.testannotationjsr250.HelloWorld"> </bean> <context:annotation-config/> </beans>
注意:當你使用@Resource注解時,此name指定的是一個bean,也就是一個類才能生效,而不是這個bean上的具體setter方法。所以這里直接用bean生成了一個String的類,然后在類的實例化傳入有參的構造函數中。
測試結果:
測試工程:https://github.com/easonjim/5_java_example/tree/master/springtest/test12/testannotationjsr250