博客
关于我
@PostConstruct、@PreDestroy注解总结
阅读量:405 次
发布时间:2019-03-05

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

文章目录

1 应用场景

  • @PostConstruct:想在spring中生成一个对象之后,完成一些初始化操作,而这些操作需要某些依赖注入,不能在构造方法执行,比如生成一个对象后,查询数据字典。使用@PostConstruct注解一个方法,这个方法将在依赖注入完成后执行一次,仅执行一次。
  • @PreDestroy:spring中销毁一个对象前,释放一些资源等。

2 加载顺序

  • spring中执行顺序:Constructor >> @Autowired >> @PostConstruct;
  • 服务器加载Servlet -> servlet 构造函数的加载 -> postConstruct ->init(init是在service 中的初始化方法. 创建service 时发生的事件.) ->Service->destory->predestory->服务器卸载serlvet

3 代码示例

@Componentpublic class DbInit {        @Autowired    private UserRepository userRepository;     @PostConstruct    private void postConstruct() {           User admin = new User("admin", "admin password");        User normalUser = new User("user", "user password");        userRepository.save(admin, normalUser);    }}
@Componentpublic class UserRepository {        private DbConnection dbConnection;    @PreDestroy    public void preDestroy() {           dbConnection.close();    }}

4 Java9+

@PostConstruct 和@PreDestroy 是JavaEE的一部分,因为Java EE在Java9已经被标deprecated,并且在Java11移除,所以在Java11及以上版本要加如下注解:

javax.annotation
javax.annotation-api
1.3.2

转载地址:http://zphwz.baihongyu.com/

你可能感兴趣的文章
Navicat 导入sql文件
查看>>
navicat 添加外键1215错误
查看>>
navicat 系列软件一点击菜单栏就闪退
查看>>
navicat 自动关闭_干掉Navicat!MySQL官方客户端到底行不行?
查看>>
Navicat 设置时间默认值(当前最新时间)
查看>>
navicat 连接远程mysql
查看>>
navicat:2013-Lost connection to MySQL server at ‘reading initial communication packet解决方法
查看>>
Navicate for mysql 数据库设计-数据库分析
查看>>
Navicat下载和破解以及使用
查看>>
Navicat中怎样将SQLServer的表复制到MySql中
查看>>
navicat创建连接 2002-can‘t connect to server on localhost(10061)且mysql服务已启动问题
查看>>
Navicat可视化界面导入SQL文件生成数据库表
查看>>
Navicat向sqlserver中插入数据时提示:当 IDENTITY_INSERT 设置为 OFF 时,不能向表中的标识列插入显式值
查看>>
Navicat因导入的sql文件中时间数据类型有参数而报错的原因(例:datetime(3))
查看>>
Navicat如何连接MySQL
查看>>
navicat导入.sql文件出错2006- MySQLserver has gone away
查看>>
Navicat导入海量Excel数据到数据库(简易介绍)
查看>>
Navicat工具Oracle数据库复制 or 备用、恢复功能(评论都在谈论需要教)
查看>>
Navicat工具中建立数据库索引
查看>>
navicat工具查看MySQL数据库_表占用容量_占用空间是多少MB---Linux工作笔记048
查看>>