From 89433d782a834ae4ab1835a0b70fa16340bbbd49 Mon Sep 17 00:00:00 2001
From: Junjie <fallin.jie@qq.com>
Date: 星期一, 13 四月 2026 19:41:20 +0800
Subject: [PATCH] #算法耗时优化

---
 src/main/java/com/zy/core/trace/StationTaskTraceRegistry.java |   43 +++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 43 insertions(+), 0 deletions(-)

diff --git a/src/main/java/com/zy/core/trace/StationTaskTraceRegistry.java b/src/main/java/com/zy/core/trace/StationTaskTraceRegistry.java
index e9eb870..c366e70 100644
--- a/src/main/java/com/zy/core/trace/StationTaskTraceRegistry.java
+++ b/src/main/java/com/zy/core/trace/StationTaskTraceRegistry.java
@@ -205,6 +205,31 @@
         return result;
     }
 
+    public List<StationTaskTraceVo> listPlanningActiveTraceSnapshots() {
+        ensureCacheLoaded();
+        cleanupExpired();
+        List<StationTaskTraceVo> result = new ArrayList<>();
+        for (TraceTaskState state : taskStateMap.values()) {
+            if (state == null) {
+                continue;
+            }
+            StationTaskTraceVo traceVo = state.toPlanningVo();
+            if (traceVo == null) {
+                continue;
+            }
+            result.add(traceVo);
+        }
+        result.sort(new Comparator<StationTaskTraceVo>() {
+            @Override
+            public int compare(StationTaskTraceVo a, StationTaskTraceVo b) {
+                long av = a.getUpdatedAt() == null ? 0L : a.getUpdatedAt();
+                long bv = b.getUpdatedAt() == null ? 0L : b.getUpdatedAt();
+                return Long.compare(bv, av);
+            }
+        });
+        return result;
+    }
+
     private void cleanupExpired() {
         long now = System.currentTimeMillis();
         for (Map.Entry<Integer, TraceTaskState> entry : taskStateMap.entrySet()) {
@@ -703,6 +728,24 @@
             return vo;
         }
 
+        private synchronized StationTaskTraceVo toPlanningVo() {
+            if (isTerminalStatus(this.status)) {
+                return null;
+            }
+            StationTaskTraceVo vo = new StationTaskTraceVo();
+            vo.setTaskNo(taskNo);
+            vo.setThreadImpl(threadImpl);
+            vo.setStatus(status);
+            vo.setTraceVersion(traceVersion);
+            vo.setStartStationId(startStationId);
+            vo.setCurrentStationId(currentStationId);
+            vo.setFinalTargetStationId(finalTargetStationId);
+            vo.setPendingStationIds(copyIntegerList(pendingStationIds));
+            vo.setLatestIssuedSegmentPath(copyIntegerList(latestIssuedSegmentPath));
+            vo.setUpdatedAt(updatedAt);
+            return vo;
+        }
+
         private synchronized TraceSnapshot toSnapshot() {
             TraceSnapshot snapshot = new TraceSnapshot();
             snapshot.setTaskNo(taskNo);

--
Gitblit v1.9.1