From 00d54db361d697cf8fdf2f15940f4650b21b3185 Mon Sep 17 00:00:00 2001
From: zhubaomin <zhubaomin>
Date: 星期一, 21 四月 2025 15:05:35 +0800
Subject: [PATCH] Merge branch 'master' of http://8.140.179.55:20000/r/pipIrr-SV

---
 pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/tasks/FromRtuComResultConstantTask.java |  112 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 112 insertions(+), 0 deletions(-)

diff --git a/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/tasks/FromRtuComResultConstantTask.java b/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/tasks/FromRtuComResultConstantTask.java
new file mode 100644
index 0000000..c88ca9e
--- /dev/null
+++ b/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/tasks/FromRtuComResultConstantTask.java
@@ -0,0 +1,112 @@
+package com.dy.rtuMw.server.tasks;
+
+import com.dy.rtuMw.server.rtuData.RtuComResultNode;
+import com.dy.rtuMw.server.rtuData.RtuComResultCache;
+import com.dy.common.mw.core.CoreTask;
+import com.dy.common.queue.Node;
+import org.apache.logging.log4j.LogManager;
+import org.apache.logging.log4j.Logger;
+
+/**
+ * 瀵筊TU涓婅鏁版嵁杩涜涓氬姟澶勭悊
+ */
+public class FromRtuComResultConstantTask extends CoreTask {
+    private static final Logger log = LogManager.getLogger(FromRtuComResultConstantTask.class.getName());
+
+    /**
+     * 鍦ㄥ崟绾跨▼鐜涓繍琛�
+     */
+    @Override
+    public Integer execute() {
+        try{
+            dealRtuComResult() ;
+        }catch(Exception e){
+            log.error(e);
+        }
+        return RtuComResultCache.size()>0?0:1 ;
+    }
+    /**
+     * 澶勭悊涓婅鍛戒护缁撴灉
+     */
+    public void dealRtuComResult() {
+        Node first = RtuComResultCache.getFirstQueueNode() ;
+        if(first != null){
+            Node last = RtuComResultCache.getLastQueueNode() ;
+            while (last != null){
+                last = this.doDealRtuComResult(first, last);
+            }
+        }
+    }
+
+    /**
+     * 澶勭悊缂撳瓨鐨勪笂琛屾暟鎹妭鐐�
+     * @param first 绗竴涓妭鐐�
+     * @param last 鏈�鍚庝竴涓妭鐐�
+     */
+    private Node doDealRtuComResult(Node first, Node last){
+        if(last != null){
+            //鍦╠ealNode鏂规硶涓紝鍙兘瑕佹妸last浠庨槦鍒椾腑绉婚櫎锛岃繖鏃秎ast.pre涓虹┖锛屾墍浠ユ彁鍓嶆妸last.pre鍙栧嚭鏉�
+            Node pre = last.pre ;
+            dealNode(last) ;
+            if(first != last){
+                return pre ;
+            }else{
+                //鍋滄
+                return null ;
+            }
+        }else{
+            return null ;
+        }
+    }
+
+
+    ////////////////////////////////////////////////
+    //
+    //浠ヤ笅瀹炵幇锛岄噰鐢ㄤ簡閫掑綊璋冪敤锛屽綋闃熷垪缂撳瓨缁撶偣寰堝鏃讹紝浼氫骇鐢熸爤婧㈠嚭寮傚父
+    //
+    ////////////////////////////////////////////////
+//    /**
+//     * 澶勭悊涓婅鏁版嵁
+//     */
+//    public Integer dealRtuComResult_() {
+//        Node first = RtuComResultCache.getFirstQueueNode() ;
+//        if(first != null){
+//            Integer count = RtuComResultCache.size() ;
+//            Node last = RtuComResultCache.getLastQueueNode() ;
+//            this.doDealRtuComResult_(first, last);
+//            return count ;
+//        }
+//        return null ;
+//    }
+//
+//    /**
+//     * 澶勭悊缂撳瓨鐨勪笂琛屾暟鎹妭鐐�
+//     * @param first 绗竴涓妭鐐�
+//     * @param last 鏈�鍚庝竴涓妭鐐�
+//     */
+//    private void doDealRtuComResult_(Node first, Node last){
+//        if(last != null){
+//            //鍦╠ealNode鏂规硶涓紝鍙兘瑕佹妸last浠庨槦鍒椾腑绉婚櫎锛岃繖鏃秎ast.pre涓虹┖锛屾墍浠ユ彁鍓嶆妸last.pre鍙栧嚭鏉�
+//            Node pre = last.pre ;
+//            dealNode(last) ;
+//            if(first != last){
+//                doDealRtuComResult_(first, pre) ;
+//            }else{
+//                //鍋滄
+//            }
+//        }
+//    }
+//
+    /**
+     * 澶勭悊涓�涓妭鐐�
+     * @param node 鑺傜偣
+     */
+    private void dealNode(Node node){
+        if(node != null && node.obj != null){
+            RtuComResultNode obj = (RtuComResultNode)node.obj ;
+            obj.dealSelf() ;
+            RtuComResultCache.removeNode(node);
+        }
+    }
+
+}

--
Gitblit v1.8.0