From 3cfb3d987566f4baf5563a52dced85c9bd8a5391 Mon Sep 17 00:00:00 2001
From: dd <gitluke@outlook.com>
Date: Fri, 26 Dec 2025 01:47:15 +0800
Subject: [PATCH] 1
---
src/main/java/com/nq/utils/task/YEBTask.java | 26 ++++++++++----------------
1 files changed, 10 insertions(+), 16 deletions(-)
diff --git a/src/main/java/com/nq/utils/task/YEBTask.java b/src/main/java/com/nq/utils/task/YEBTask.java
index e67ff51..7b49ec2 100644
--- a/src/main/java/com/nq/utils/task/YEBTask.java
+++ b/src/main/java/com/nq/utils/task/YEBTask.java
@@ -1,15 +1,13 @@
package com.nq.utils.task;
-
import com.nq.service.IEchoServices;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
-import java.util.concurrent.TimeUnit;
-import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;
+import java.util.concurrent.atomic.AtomicBoolean;
/**
* 余额宝定时任务
@@ -18,34 +16,30 @@
@Component
public class YEBTask {
-
@Autowired
- IEchoServices echoServices;
+ private IEchoServices echoServices;
- boolean sendYEBMoney = true;
-
- private final Lock sendYEBMoneyLock = new ReentrantLock();
+ private final ReentrantLock sendYEBMoneyLock = new ReentrantLock();
+ private final AtomicBoolean isSendYEBMoney = new AtomicBoolean(false);
/**
* 余额宝发放利息
*/
@Scheduled(cron = "0 0/1 * * * ?")
public void sendYEBMoney() {
- if (sendYEBMoney) // 定义一个布尔变量,代表新闻任务是否在处理中
+ if (isSendYEBMoney.get()) { // 判断任务是否在处理中
return;
- sendYEBMoney = true; // 设置处理中标识为 true
- if (sendYEBMoneyLock.tryLock()) {
+ }
+ if (sendYEBMoneyLock.tryLock()) { // 尝试获取锁
+ isSendYEBMoney.set(true); // 设置处理中标识为true
try {
-
log.info("基金定时任务-------开始");
echoServices.sendMoney();
log.info("基金定时任务-------结束");
-
} finally {
- sendYEBMoneyLock.unlock();
- sendYEBMoney = false;
+ sendYEBMoneyLock.unlock(); // 释放锁
+ isSendYEBMoney.set(false); // 设置处理中标识为false
}
}
}
-
}
--
Gitblit v1.9.3