博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
注解@PostConstruct与@PreDestroy讲解及实例
阅读量:6036 次
发布时间:2019-06-20

本文共 2717 字,大约阅读时间需要 9 分钟。

 

从Java EE 5规范开始,Servlet中增加了两个影响Servlet生命周期的注解(Annotion);@PostConstruct和@PreDestroy。这两个注解被用来修饰一个非静态的void()方法 。写法有如下两种方式:

@PostConstruct

Public void someMethod() {}

                                                                                    
或者

public @PostConstruct void someMethod(){}

    被@PostConstruct修饰的方法会在服务器加载Servle的时候运行,并且只会被服务器执行一次。PostConstruct在构造函数之后执行,init()方法之前执行。PreDestroy()方法在destroy()方法执行执行之后执行

 

 

 

 

被注解的Servlet生命周期

    需要注意的是,注解会多多少少地影响到服务器的启动速度。服务器在启动时候会遍历Web 应用的WEB-INF/classes下的所有class文件与WEB-INF/lib下的所有jar文件,以检查哪些类使用了注解。如果应用程序中没有 使用任何注解,可以在Web.xml中设置的metadata-complete属性为true.(支持@PostConstruct和 @PreDestroy的服务器需要支持Servlet2.5规范。Tomcat5.x仅支持Servlet2.4规范。)

 

我现在要说的是用实例说明它有什么作用。

比如说我有一种情况,在我的servlet初始化加载之前我想处理一些东西,像加载缓存等等。

怎么做。@PostConstruct就派上用场了。那为什么这玩意用的不多呢,这是因为如果初始化之前我们要加载或处理某些玩意完全可以在构造器初始化时就处理了,但这种方法需要自己重写构造器。好吧。直接上代码看看具体用它的时候怎么做的。

package com.whaty.products.whatysns.web.info; import javax.annotation.PostConstruct;import javax.annotation.Resource; import org.springframework.stereotype.Service;import org.springframework.util.Assert; import com.whaty.framework.cache.core.model.Cache;import com.whaty.framework.cache.core.service.CacheService;import com.whaty.framework.cache.entitycache.service.EntityCacheHelper;import com.whaty.framework.cache.entitycache.service.IEntityDaoAdapter; /** * @author bc_qi * @param 
* @param
*/@Service("AjaxCacheableService")public class AjaxCacheableService{ @Resource(name="cacheService") protected CacheService cacheService; protected boolean useReadWriteEntityDao = false; protected boolean useCache = true; protected int entityCacheMaxSize = 1000; protected int entityCacheMaxLiveSeconds = 3600; protected Cache entityCache; /** * 构造方法执行后,初始化, */ @PostConstruct public void init() { Assert.notNull(cacheService, "cacheService must be set!"); getCache(); } /** * 获取cache * @return */ protected Cache getCache() { if (entityCache == null) { entityCache = cacheService.addCache(this.getClass().getName(),entityCacheMaxLiveSeconds); } return entityCache; } /** * @param id * @param useCache 是否使用Cache * @return */ public Object getCache(String id) { String strid = String.valueOf(id); Object o = entityCache.get(strid); return o; } public Object putCache(int tTLSeconds,String cacheId,Object value) { String strid = String.valueOf(cacheId); Object o = entityCache.get(strid); if (o != null) { return o; } else { entityCache.put(strid, value, tTLSeconds); return value; } } }

 

 

参考: https://blog.csdn.net/yaerfeng/article/details/8447530?utm_source=tuicool

 

你可能感兴趣的文章
69、iSCSI共享存储配置实战
查看>>
文本编程
查看>>
乔布斯走了。你还期待苹果吗?
查看>>
优先级
查看>>
Tomcat与Web服务器、应用服务器的关系
查看>>
用DFS实现全排列 & 八皇后问题
查看>>
深度学习博客
查看>>
Android总结篇系列:Android Service
查看>>
Android dumpsys命令的使用
查看>>
Linux Kernel系列一:开篇和Kernel启动概要
查看>>
BZOJ 2756: [SCOI2012]奇怪的游戏 网络流/二分
查看>>
master + worker模式的node多核解决框架——node-cluster
查看>>
Android如何实现超级棒的沉浸式体验
查看>>
使用node打造自己的命令行工具方法教程
查看>>
Express代理中间件问题与解决方案
查看>>
||和&&返回什么?
查看>>
linux在文件中查找指定字符串,然后根据查找结果来做进一步的处理
查看>>
在Oracle中删除所有强制性外键约束
查看>>
dhcp
查看>>
【R】R语言使用命令行参数 - [编程技巧(Program Skill)]
查看>>