From adbdffdb3b80eed8c7110c0583f8ae2f216b7990 Mon Sep 17 00:00:00 2001
From: zyy <zyy@email.com>
Date: Mon, 13 Oct 2025 18:22:59 +0800
Subject: [PATCH] K线优化

---
 trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/CryptosKlineServiceImpl.java |   58 +++++++++++++++++++++++++---------------------------------
 1 files changed, 25 insertions(+), 33 deletions(-)

diff --git a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/CryptosKlineServiceImpl.java b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/CryptosKlineServiceImpl.java
index 29edd48..adb3830 100644
--- a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/CryptosKlineServiceImpl.java
+++ b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/CryptosKlineServiceImpl.java
@@ -179,8 +179,7 @@
 
     @Override
     public void saveOneByHuoBi(String symbol, String line) {
-        List<Kline> list = hobiDataService.kline(itemService.findBySymbol(symbol).getSymbol(), line, 2,
-                0);
+        List<Kline> list = hobiDataService.kline(itemService.findBySymbol(symbol).getSymbol(), line, 2);
         if (list == null || list.isEmpty()) {
             return;
         }
@@ -193,39 +192,31 @@
                 kline.setLow(kline.getLow().add(currentValue));
                 kline.setHigh(kline.getHigh().add(currentValue));
                 kline.setAdjusted(true);
-
-
-                Kline lastOne = null;
-
-                List<Kline> lastList = this.find(symbol, line, 1);
-                if (lastList.size() > 0) {
-                    lastOne = list.get(0);
-                }
-                if (lastOne != null) {
-                    BigDecimal diff = kline.getOpen().subtract(lastOne.getClose());
-                    if (diff.compareTo(BigDecimal.ZERO) > 0) { //补差
-                        kline.setOpen(kline.getOpen().subtract(diff));
-                        kline.setLow(kline.getLow().subtract(diff));
-                    } else if (diff.compareTo(BigDecimal.ZERO) < 0) {
-                        kline.setOpen(kline.getOpen().subtract(diff));
-                        kline.setHigh(kline.getHigh().subtract(diff));
-                    }
-                }
-                /*BigDecimal last = AdjustmentValueCache.getLastValue().get(symbol);
-                if (last != null && last.compareTo(BigDecimal.ZERO) > 0) {
-                    BigDecimal adj = currentValue.subtract(last);
-                    if (adj.compareTo(BigDecimal.ZERO) > 0) { //递增
-                        kline.setOpen(kline.getOpen().subtract(adj));
-                        kline.setLow(kline.getLow().subtract(adj));
-                    } else if(adj.compareTo(BigDecimal.ZERO) < 0){ //递减
-                        kline.setOpen(kline.getOpen().subtract(adj));
-                        kline.setHigh(kline.getHigh().subtract(adj));
-                    }
-                } else {
-                    AdjustmentValueCache.getLastValue().put(symbol, currentValue);
-                }*/
             }
         }
+
+
+        //获取上一条数据
+        Kline lastKline = DataCache.getLastKline().get(symbol + line);;
+        if (lastKline == null) {
+            List<Kline> lastList = this.find(symbol, line, 1);
+            if (lastList.size() > 0) {
+                lastKline = lastList.get(0);
+            }
+        }
+        //补差
+        if (lastKline != null) {
+            BigDecimal diff = kline.getOpen().subtract(lastKline.getClose());
+            if (diff.compareTo(BigDecimal.ZERO) > 0) {
+                kline.setOpen(kline.getOpen().subtract(diff));
+                kline.setLow(kline.getLow().subtract(diff));
+            } else if (diff.compareTo(BigDecimal.ZERO) < 0) {
+                kline.setOpen(kline.getOpen().subtract(diff));
+                kline.setHigh(kline.getHigh().subtract(diff));
+            }
+        }
+
+
         RequestDataHelper.set("symbol", symbol);
         klineDBService.save(kline);
         KlineTimeObject timeObject = DataCache.getKline(symbol, line);
@@ -235,6 +226,7 @@
         timeObject.getKline().add(kline);
         timeObject.setLastTime(new Date());
         DataCache.putKline(symbol, line, timeObject);
+        DataCache.getLastKline().put(symbol + line, kline);
         RequestDataHelper.clear();
     }
 

--
Gitblit v1.9.3