From 7f66dd2dee66a81df6ab999fc9daea3ac60a3642 Mon Sep 17 00:00:00 2001
From: liurunyu <lry9898@163.com>
Date: 星期一, 20 一月 2025 13:52:44 +0800
Subject: [PATCH] 优化代码

---
 pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/upgrade/UpgradeRtuDev.java |  152 ++++++++++++++++++++++++++++++--------------------
 1 files changed, 92 insertions(+), 60 deletions(-)

diff --git a/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/upgrade/UpgradeRtuDev.java b/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/upgrade/UpgradeRtuDev.java
index 08b0b4f..6b12947 100644
--- a/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/upgrade/UpgradeRtuDev.java
+++ b/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/upgrade/UpgradeRtuDev.java
@@ -5,9 +5,11 @@
 import com.dy.common.mw.protocol.CommandType;
 import com.dy.common.softUpgrade.Com1601Vo;
 import com.dy.common.softUpgrade.state.UpgradeRtu;
+import com.dy.common.softUpgrade.state.UpgradeTaskVo;
 import com.dy.common.util.Callback;
 import com.dy.common.util.DateTime;
 import lombok.Data;
+import lombok.EqualsAndHashCode;
 
 /**
  * @Author: liurunyu
@@ -15,36 +17,44 @@
  * @Description
  */
 @Data
+@EqualsAndHashCode(callSuper=false)
 public class UpgradeRtuDev extends UpgradeRtu {
 
     @JSONField(serialize = false)
-    private UpgradeTask task ;
+    private Integer failTryTimes ;//鍗囩骇澶辫触鍚庯紝閲嶆柊鍋胯瘯鍗囩骇娆℃暟锛�0琛ㄧず涓嶉噸鏂板伩璇曞崌绾�
+
+    @JSONField(serialize = false)
+    public UpgradeTaskVo taskVo ;//鍗囩骇浠诲姟鍊煎璞�
 
     private UpgradeRtuDev(){
     }
 
-    public UpgradeRtuDev(UpgradeTask task, String rtuAddr, int totalPackage) {
+    public UpgradeRtuDev(UpgradeTaskVo taskVo, Integer failTryTimes , String rtuAddr, int totalPackage) {
         super();
-        this.task = task ;
+        this.taskVo = taskVo ;
+        this.failTryTimes = failTryTimes ;
         this.rtuAddr = rtuAddr ;
         this.state = STATE_UNSTART ;
         this.totalPackage = totalPackage ;
         this.currentPackage = 0 ;
         this.currentRamAddr = 0 ;
         this.lastDownDt = "" ;
+        this.lastDownDtAt = 0L ;
         this.reTryTimes = 0 ;
         this.isOver = false ;
     }
 
-    public UpgradeRtuDev(UpgradeTask task, String rtuAddr, int totalPackage, int state) {
+    public UpgradeRtuDev(UpgradeTaskVo taskVo, Integer failTryTimes, String rtuAddr, int totalPackage, int state) {
         super();
-        this.task = task ;
+        this.taskVo = taskVo ;
+        this.failTryTimes = failTryTimes ;
         this.rtuAddr = rtuAddr ;
         this.state = state ;
         this.totalPackage = totalPackage ;
         this.currentPackage = 0 ;
         this.currentRamAddr = 0 ;
         this.lastDownDt = "" ;
+        this.lastDownDtAt = 0L ;
         this.reTryTimes = 0 ;
         this.isOver = false ;
     }
@@ -57,74 +67,96 @@
      */
     @Override
     public void trigger(String code, String protocolName, Short protocolVersion, byte[][] softData, Callback callbackCom){
-        if(this.state == STATE_OFFLINE || this.state == STATE_UNSTART){
-            //褰撳墠鏈紑濮嬪崌绾ц繃绋嬶紝涓嬪彂鍗囩骇閰嶇疆鎸囦护
-            this.setStateAtCom1601Time();
-            callbackCom.call(createCommand1601(protocolName, protocolVersion));
-        }else if(this.state == STATE_RUNNING){
-            //褰撳墠鍗囩骇杩囩▼涓�
-            if(code.equals(UpgradeCode.cd_1601)){
-                //涓嬪彂閰嶇疆杩斿洖
-                this.lastDownDt = DateTime.yyyy_MM_dd_HH_mm_ss() ;
-                callbackCom.call(createCommand1602(protocolName, protocolVersion, currentPackage, currentRamAddr, softData));//涓嬪彂鏁版嵁鍖呮寚浠�
-            }else if(code.equals(UpgradeCode.cd_1602)){
-                //涓嬪彂鏁版嵁鍖呰繑鍥�
-                currentPackage++ ;
-                currentRamAddr += RAMADDRADD ;
-                if(currentPackage < totalPackage){
+        if(!this.isOver){
+            //鍗囩骇鏈畬鎴�
+            if(this.state == STATE_OFFLINE || this.state == STATE_UNSTART){
+                //褰撳墠鏈紑濮嬪崌绾ц繃绋嬶紝涓嬪彂鍗囩骇閰嶇疆鎸囦护
+                this.setStateAtSendCom1601Time();
+                callbackCom.call(createCommand1601(protocolName, protocolVersion));
+            }else if(this.state == STATE_RUNNING){
+                //褰撳墠鍗囩骇杩囩▼涓�
+                if(code.equals(UpgradeCode.cd_9601)){
+                    //涓嬪彂閰嶇疆杩斿洖
                     this.lastDownDt = DateTime.yyyy_MM_dd_HH_mm_ss() ;
-                    callbackCom.call(createCommand1602(protocolName, protocolVersion, currentPackage, currentRamAddr, softData));
-                }else{
-                    this.lastDownDt = DateTime.yyyy_MM_dd_HH_mm_ss() ;
-                    callbackCom.call(createCommand1603(protocolName, protocolVersion));//涓嬪彂鏍¢獙鎸囦护
-                }
-            }else if(code.equals(UpgradeCode.cd_1603)){
-                //涓嬪彂鏍¢獙杩斿洖
-                this.isOver = true ;//鍗囩骇瀹屾垚
-                this.state = STATE_SUCCESS ;
-                this.lastDownDt = DateTime.yyyy_MM_dd_HH_mm_ss() ;
-                callbackCom.call(createCommand1600(protocolName, protocolVersion));//涓嬪彂澶嶄綅鎸囦护锛屾鎸囦护鏃犲簲绛�
-            }else{
-                if(!this.isOver){
-                    //鍗囩骇鏈畬鎴�
-                    if(this.state == STATE_FAILONE || this.state == STATE_FAIL){
-                        //宸茬粡鏄崌绾уけ璐ユ��
-                        if(this.reTryTimes < task.failTryTimes){
-                            //閲嶈瘯娆℃暟鏈揪鍒颁笂闄愶紝缁х画閲嶈瘯
-                            this.reTryTimes += 1 ;
-                            this.setStateAtCom1601Time();
-                            callbackCom.call(createCommand1601(protocolName, protocolVersion));//涓嬪彂閰嶇疆鎸囦护
-                        }else{
-                            this.isOver = true ;//鍗囩骇瀹屾垚
-                        }
+                    this.lastDownDtAt = System.currentTimeMillis() ;
+                    callbackCom.call(createCommand1602(protocolName, protocolVersion, currentPackage, currentRamAddr, softData));//涓嬪彂鏁版嵁鍖呮寚浠�
+                }else if(code.equals(UpgradeCode.cd_9602)){
+                    //涓嬪彂鏁版嵁鍖呰繑鍥�
+                    currentPackage++ ;
+                    currentRamAddr += RAMADDRADD ;
+                    if(currentPackage < totalPackage){
+                        this.lastDownDt = DateTime.yyyy_MM_dd_HH_mm_ss() ;
+                        this.lastDownDtAt = System.currentTimeMillis() ;
+                        callbackCom.call(createCommand1602(protocolName, protocolVersion, currentPackage, currentRamAddr, softData));
                     }else{
-                        //闈炲崌绾у姛鑳界爜锛屽鏋滃湪鍗囩骇杩囩▼涓敹鍒拌繖涓姛鑳界爜鐨勪笂琛屾暟鎹紝璇存槑鍗囩骇澶辫触浜�
-                        if(currentPackage == 0 || currentPackage == 1){
-                            //1鍖呮锛屽崌绾уけ璐�
-                            this.state = STATE_FAILONE ;
-                        }else{
-                            //闈�1鍖呮锛屽崌绾уけ璐�
-                            this.state = STATE_FAIL ;
-                        }
+                        this.lastDownDt = DateTime.yyyy_MM_dd_HH_mm_ss() ;
+                        this.lastDownDtAt = System.currentTimeMillis() ;
+                        callbackCom.call(createCommand1603(protocolName, protocolVersion));//涓嬪彂鏍¢獙鎸囦护
                     }
+                }else if(code.equals(UpgradeCode.cd_9603)){
+                    //涓嬪彂鏍¢獙杩斿洖
+                    this.setStateAtReceiveRes9603Time() ;
+                    callbackCom.call(createCommand1600(protocolName, protocolVersion));//涓嬪彂澶嶄綅鎸囦护锛屾鎸囦护鏃犲簲绛�
                 }else{
-                    //鍗囩骇瀹屾垚锛屾棤涓氬姟閫昏緫
+                    //褰撳墠鏄崌绾т腑鐘舵�侊紝骞朵笖鍗囩骇鏈畬鎴愶紝鏀跺埌浜嗛潪960X绯诲垪鍔熻兘鐮侊紝鍒欏崌绾уけ璐�
+                    if(currentPackage == 0 || currentPackage == 1){
+                        //1鍖呮锛屽崌绾уけ璐�
+                        this.state = STATE_FAILONE ;
+                    }else{
+                        //闈�1鍖呮锛屽崌绾уけ璐�
+                        this.state = STATE_FAIL ;
+                    }
                 }
+            }else if(this.state == STATE_FAILONE || this.state == STATE_FAIL){
+                //涓婃璁剧疆浜嗗け璐ョ姸鎬侊紝骞朵笖鍗囩骇鏈畬鎴愶紝鏀跺埌浜嗛潪960X绯诲垪鍔熻兘鐮侊紝鍒欏崌绾уけ璐�
+                if(this.reTryTimes < this.failTryTimes){
+                    //閲嶈瘯娆℃暟鏈揪鍒颁笂闄愶紝缁х画閲嶈瘯
+                    this.reTryTimes += 1 ;
+                    this.setStateAtSendCom1601Time();
+                    callbackCom.call(createCommand1601(protocolName, protocolVersion));//涓嬪彂閰嶇疆鎸囦护
+                }else{
+                    //鍗囩骇澶辫触锛屽苟涓旈噸璇曟鏁拌揪鍒颁笂闄愶紝寮哄埗璁剧疆鍗囩骇瀹屾垚
+                    this.isOver = true ;
+                }
+            }else if(this.state == STATE_SUCCESS){
+                //鍗囩骇鎴愬姛鎬侊紝涓嶄細鍑虹幇姝ゆ儏鍐碉紝鍥犱负璁剧疆涓烘垚鍔熸�佹椂锛屽崌绾х粨鏉熷睘鎬sOver璁剧疆涓簍rue浜�
+                //涓哄畨鍏ㄨ锛岃繖閲屽啀璁剧疆涓虹粨鏉熸��
+                this.isOver = true ;
+            }else if(this.state == STATE_FAILOFFLINE){
+                //宸茬粡琚叾浠栭�昏緫妯″潡寮哄埗璁剧疆鎴愮绾垮け璐ユ�佷簡锛屼笉浼氬嚭鐜版鎯呭喌锛屽洜涓鸿缃负绂荤嚎澶辫触鎬佹椂锛屽崌绾х粨鏉熷睘鎬sOver璁剧疆涓簍rue浜�
+                //杩欓噷涓嶅啀鏈変綔涓�
+                //涓哄畨鍏ㄨ锛岃繖閲屽啀璁剧疆涓虹粨鏉熸��
+                this.isOver = true ;
+            }else{
+                //鍏朵粬鐘舵�侊紙娌℃湁鍏朵粬鎬佷簡锛岄櫎闈炲啀璁捐寮�鍙戞椂澧炲姞浜嗙姸鎬侊級
+                //涓哄畨鍏ㄨ锛岃繖閲屽啀璁剧疆涓虹粨鏉熸��
+                this.isOver = true ;
             }
         }else{
-            //鍦ㄥ叾浠栫姸鎬佷笅锛屼笉瑙﹀彂浠诲姟宸ヤ綔
+            //鍗囩骇瀹屾垚锛屾棤涓氬姟閫昏緫
         }
     }
 
     /**
      * 璁剧疆鍙戦�侀厤缃懡浠ゆ椂鍒荤殑鐘舵��
      */
-    private void setStateAtCom1601Time(){
-        this.state = STATE_RUNNING;
+    private void setStateAtSendCom1601Time(){
+        this.state = STATE_RUNNING;//鍗囩骇杩涜涓�
         this.currentPackage = 0 ;
         this.currentRamAddr = 0 ;
         this.isOver = false ;
         this.lastDownDt = DateTime.yyyy_MM_dd_HH_mm_ss() ;
+        this.lastDownDtAt = System.currentTimeMillis() ;
+    }
+
+    /**
+     * 璁剧疆1603鎸囦护杩斿洖鏃跺埢鐨勭姸鎬�
+     */
+    private void setStateAtReceiveRes9603Time(){
+        this.isOver = true ;//鍗囩骇瀹屾垚
+        this.state = STATE_SUCCESS ;
+        this.lastDownDt = DateTime.yyyy_MM_dd_HH_mm_ss() ;
+        this.lastDownDtAt = System.currentTimeMillis() ;
     }
 
     @Override
@@ -139,10 +171,10 @@
         com.rtuResultSendWebUrl = Command.ignoreRtuResultSendWebUrl ;
 
         Com1601Vo vo = new Com1601Vo() ;
-        vo.softStoreAddr = this.task.taskVo.softStoreAddr ;
-        vo.softStartAddr = this.task.taskVo.softStartAddr ;
-        vo.totalByte =  this.task.taskVo.softBytesCalculate ;
-        vo.softCrc = this.task.taskVo.softByteSrc16;
+        vo.softStoreAddr = this.taskVo.softStoreAddr ;
+        vo.softStartAddr = this.taskVo.softStartAddr ;
+        vo.totalByte =  this.taskVo.softBytesCalculate ;
+        vo.softCrc = this.taskVo.softByteSrc16;
         com.param = vo ;
         return com ;
     }

--
Gitblit v1.8.0