修复SystemTimer无法结束进程问题

This commit is contained in:
Looly 2023-05-20 01:55:45 +08:00
parent 7a4f295be0
commit 47759928ac
3 changed files with 38 additions and 1 deletions

View File

@ -2,7 +2,7 @@
# 🚀Changelog # 🚀Changelog
------------------------------------------------------------------------------------------------------------- -------------------------------------------------------------------------------------------------------------
# 5.8.19.M1 (2023-05-19) # 5.8.19.M1 (2023-05-20)
### 🐣新特性 ### 🐣新特性
* 【db 】 优化HttpRequest.toString()内容打印issue#3072@Github * 【db 】 优化HttpRequest.toString()内容打印issue#3072@Github
@ -24,6 +24,7 @@
* 【core 】 修复NumberUtil mul 传入null的string入参报错问题issue#I70JB3@Gitee * 【core 】 修复NumberUtil mul 传入null的string入参报错问题issue#I70JB3@Gitee
* 【core 】 修复ZipReader.get调用reset异常问题issue#3099@Github * 【core 】 修复ZipReader.get调用reset异常问题issue#3099@Github
* 【core 】 修复FileUtil.createTempFile可能导致的漏洞issue#3103@Github * 【core 】 修复FileUtil.createTempFile可能导致的漏洞issue#3103@Github
* 【cron 】 修复SystemTimer无法结束进程问题issue#3090@Github
------------------------------------------------------------------------------------------------------------- -------------------------------------------------------------------------------------------------------------
# 5.8.18 (2023-04-27) # 5.8.18 (2023-04-27)

View File

@ -31,6 +31,7 @@ public class SystemTimer {
* 轮询delayQueue获取过期任务线程 * 轮询delayQueue获取过期任务线程
*/ */
private ExecutorService bossThreadPool; private ExecutorService bossThreadPool;
private volatile boolean isRunning;
/** /**
* 构造 * 构造
@ -56,6 +57,7 @@ public class SystemTimer {
*/ */
public SystemTimer start() { public SystemTimer start() {
bossThreadPool = ThreadUtil.newSingleExecutor(); bossThreadPool = ThreadUtil.newSingleExecutor();
isRunning = true;
bossThreadPool.submit(() -> { bossThreadPool.submit(() -> {
while (true) { while (true) {
if(false == advanceClock()){ if(false == advanceClock()){
@ -70,6 +72,7 @@ public class SystemTimer {
* 强制结束 * 强制结束
*/ */
public void stop(){ public void stop(){
this.isRunning = false;
this.bossThreadPool.shutdown(); this.bossThreadPool.shutdown();
} }
@ -91,6 +94,9 @@ public class SystemTimer {
* @return 是否结束 * @return 是否结束
*/ */
private boolean advanceClock() { private boolean advanceClock() {
if(false == isRunning){
return false;
}
try { try {
TimerTaskList timerTaskList = poll(); TimerTaskList timerTaskList = poll();
if (null != timerTaskList) { if (null != timerTaskList) {

View File

@ -0,0 +1,30 @@
/*
* Copyright (c) 2023 looly(loolly@aliyun.com)
* Hutool is licensed under Mulan PSL v2.
* You can use this software according to the terms and conditions of the Mulan PSL v2.
* You may obtain a copy of Mulan PSL v2 at:
* http://license.coscl.org.cn/MulanPSL2
* THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
* EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
* MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
* See the Mulan PSL v2 for more details.
*/
package cn.hutool.cron.timingwheel;
import cn.hutool.core.lang.Console;
public class Issue3090Test {
public static void main(String[] args) {
final SystemTimer timer = new SystemTimer();
timer.setDelayQueueTimeout(1000);
timer.start();
timer.addTask(new TimerTask(() -> {
Console.log(1);
Console.log("任务已经完成");
}, 1000));
timer.stop();
Console.log("线程池已经关闭");
}
}