From 6a18d6cffcb67e361db8345a4323d5782d1fe32a Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Tue, 20 May 2025 16:10:10 +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