From 45e55401d2298a9689295b75d544cc5fa2cef787 Mon Sep 17 00:00:00 2001
From: zyy <zyy@email.com>
Date: Fri, 10 Oct 2025 12:08:46 +0800
Subject: [PATCH] 调整值优化
---
trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/CryptosKlineServiceImpl.java | 53 +++++++++++++++++++++++++++++++++++++++++++++++++----
1 files changed, 49 insertions(+), 4 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 bf74cac..7821323 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
@@ -131,7 +131,8 @@
@Override
public void saveOne(String symbol, String line) {
- RequestDataHelper.set("symbol", symbol);
+ saveOneByHuoBi(symbol, line);
+ /*RequestDataHelper.set("symbol", symbol);
Realtime realtime = DataCache.getRealtime(symbol);
if (realtime == null) {
logger.error("saveOne error, realtime is null,symbol [" + symbol + "]");
@@ -147,11 +148,11 @@
String key = symbol + "_" + line;
Kline hobiOne = DataCache.getKline_hobi().get(key);
- /*if (hobiOne == null || lastOne == null) {
+ *//*if (hobiOne == null || lastOne == null) {
logger.error("saveOne error, hobiOne is null,symbol [" + symbol + "]");
// 取不到远程数据,直接退出
return;
- }*/
+ }*//*
RequestDataHelper.set("symbol", symbol);
Kline kline = this.bulidKline(realtime, lastOne, null, line);
kline.setPeriod(line);
@@ -166,10 +167,54 @@
timeObject.getKline().add(kline);
timeObject.setLastTime(new Date());
DataCache.putKline(symbol, line, timeObject);
- RequestDataHelper.clear();
+ RequestDataHelper.clear();*/
}
+ @Override
+ public void saveOneByHuoBi(String symbol, String line) {
+ RequestDataHelper.set("symbol", symbol);
+ List<Kline> list = hobiDataService.kline(itemService.findBySymbol(symbol).getSymbol(), line, 2,
+ 0);
+ if (list == null || list.isEmpty()) {
+ return;
+ }
+ Kline kline = list.get(0);
+ BigDecimal currentValue = AdjustmentValueCache.getCurrentValue().get(symbol);
+ if (currentValue != null && currentValue.compareTo(BigDecimal.ZERO) > 0) {
+ if (!kline.isAdjusted()){
+ kline.setClose(kline.getClose().add(currentValue));
+ kline.setOpen(kline.getOpen().add(currentValue));
+ kline.setLow(kline.getLow().add(currentValue));
+ kline.setHigh(kline.getHigh().add(currentValue));
+ kline.setAdjusted(true);
+
+ 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);
+ }
+ }
+ }
+ klineDBService.save(kline);
+ KlineTimeObject timeObject = DataCache.getKline(symbol, line);
+ if (timeObject == null) {
+ timeObject = new KlineTimeObject();
+ }
+ timeObject.getKline().add(kline);
+ timeObject.setLastTime(new Date());
+ DataCache.putKline(symbol, line, timeObject);
+ RequestDataHelper.clear();
+ }
+
public Kline bulidKline(Realtime realtime, Kline lastOne, Kline hobiOne, String line) {
Kline kline = new Kline();
kline.setSymbol(realtime.getSymbol());
--
Gitblit v1.9.3