From b28a97e1bf66e3279e78f31ce58122427787ceec Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Thu, 11 Jun 2026 09:44:20 +0800
Subject: [PATCH] 1
---
trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/RemoteDataServiceImpl.java | 130 +++++++++++++++++++++++++++++-------------
1 files changed, 89 insertions(+), 41 deletions(-)
diff --git a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/RemoteDataServiceImpl.java b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/RemoteDataServiceImpl.java
index 785ae72..539d133 100644
--- a/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/RemoteDataServiceImpl.java
+++ b/trading-order-huobi/src/main/java/com.yami.trading.huobi/data/internal/RemoteDataServiceImpl.java
@@ -11,6 +11,7 @@
import com.yami.trading.bean.data.domain.Depth;
import com.yami.trading.bean.data.domain.Trade;
import com.yami.trading.bean.data.domain.Trend;
+import com.yami.trading.huobi.hobi.HobiDataService;
import com.yami.trading.service.data.DataService;
import com.yami.trading.service.item.ItemService;
import com.yami.trading.service.syspara.SysparaService;
@@ -22,6 +23,7 @@
import java.util.Collections;
import java.util.Date;
import java.util.List;
+import java.util.Objects;
@Service("remoteDataService")
public class RemoteDataServiceImpl implements DataService {
@@ -32,6 +34,8 @@
private SysparaService sysparaService;
@Autowired
private KlineService klineService;
+ @Autowired
+ private HobiDataService hobiDataService;
@Override
public List<Realtime> realtime(String symbols) {
@@ -74,7 +78,7 @@
@Override
public List<Kline> kline(String symbol, String line) {
Item bySymbol = itemService.findBySymbol(symbol);
- if(Item.cryptos.equals(bySymbol.getType())){
+ if (Item.cryptos.equals(bySymbol.getType()) && !bySymbol.isFake()) {
return klineCryptos(symbol, line);
}
KlineTimeObject timeObject = DataCache.getKline(symbol, line);
@@ -95,38 +99,7 @@
e.printStackTrace();
}
- Realtime realtime = DataCache.getLatestRealTime(symbol);
- if (realtime != null) {
- Kline kline = null;
- if (KlineConstant.PERIOD_1MIN.equals(line)) {
- kline = klineService.bulidKline1Minute(realtime, KlineConstant.PERIOD_1MIN);
- } else if (KlineConstant.PERIOD_5MIN.equals(line)) {
- kline = klineService.bulidKline5Minute(realtime, KlineConstant.PERIOD_5MIN);
- } else if (KlineConstant.PERIOD_15MIN.equals(line)) {
- kline = klineService.bulidKline15Minute(realtime, KlineConstant.PERIOD_15MIN);
- } else if (KlineConstant.PERIOD_30MIN.equals(line)) {
- kline = klineService.bulidKline30Minute(realtime, KlineConstant.PERIOD_30MIN);
- } else if (KlineConstant.PERIOD_60MIN.equals(line)) {
- kline = klineService.bulidKline60Minute(realtime, KlineConstant.PERIOD_60MIN);
- } else if (KlineConstant.PERIOD_4HOUR.equals(line)) {
- kline = klineService.bulidKline4Hour(realtime, KlineConstant.PERIOD_4HOUR);
- } else if (KlineConstant.PERIOD_1DAY.equals(line)) {
- kline = klineService.bulidKline1Day(realtime, KlineConstant.PERIOD_1DAY);
- } else if (KlineConstant.PERIOD_5DAY.equals(line)) {
- kline = klineService.bulidKline5Day(realtime, KlineConstant.PERIOD_5DAY);
- } else if (KlineConstant.PERIOD_1WEEK.equals(line)) {
- kline = klineService.bulidKline1Week(realtime, KlineConstant.PERIOD_1WEEK);
- } else if (KlineConstant.PERIOD_1MON.equals(line)) {
- kline = klineService.bulidKline1Mon(realtime, KlineConstant.PERIOD_1MON);
- } else if (KlineConstant.PERIOD_QUARTER.equals(line)) {
- kline = klineService.bulidKline1Mon(realtime, KlineConstant.PERIOD_QUARTER);
- } else if (KlineConstant.PERIOD_YEAR.equals(line)) {
- kline = klineService.bulidKline1Mon(realtime, KlineConstant.PERIOD_YEAR);
- }
- if (null != kline) {
- list_clone.add(kline);
- }
- }
+ appendInProgressKline(list_clone, symbol, line);
// 按时间升序
Collections.sort(list_clone);
return list_clone;
@@ -148,21 +121,96 @@
} catch (CloneNotSupportedException e) {
e.printStackTrace();
}
- Realtime realtime = DataCache.getRealtime(symbol);
- Kline hobiOne = DataCache.getKline_hobi().get(symbol + "_" + line);
-
- Kline lastOne = null;
- if (list != null && list.size() > 0) {
- lastOne = list.get(list.size() - 1);
+ // 火币 K 线倒序返回,缓存仅含已收盘 K 线;补拉最新一根未收盘 K 线
+ boolean mergedFromHobi = false;
+ Item item = itemService.findBySymbol(symbol);
+ if (item != null) {
+ List<Kline> latestKlines = hobiDataService.kline(item.getSymbol(), line, 1);
+ if (!latestKlines.isEmpty()) {
+ try {
+ Kline latest = (Kline) latestKlines.get(0).clone();
+ latest.setSymbol(symbol);
+ latest.setPeriod(line);
+ mergeLatestKline(list_clone, latest);
+ mergedFromHobi = true;
+ } catch (CloneNotSupportedException e) {
+ Kline latest = latestKlines.get(0);
+ latest.setSymbol(symbol);
+ latest.setPeriod(line);
+ mergeLatestKline(list_clone, latest);
+ mergedFromHobi = true;
+ }
+ }
}
- if (realtime != null && hobiOne != null && lastOne != null) {
- list_clone.add(this.klineService.bulidKline(realtime, lastOne, hobiOne, line));
+ if (!mergedFromHobi) {
+ appendInProgressKline(list_clone, symbol, line);
}
Collections.sort(list_clone); // 按时间升序
return list_clone;
}
+ /**
+ * 合并最新 K 线:同时间戳则更新(未收盘 K 线持续变化),否则追加。
+ */
+ private void mergeLatestKline(List<Kline> list, Kline latest) {
+ if (latest == null || latest.getTs() == null) {
+ return;
+ }
+ if (list.isEmpty()) {
+ list.add(latest);
+ return;
+ }
+ Kline last = list.get(list.size() - 1);
+ if (Objects.equals(last.getTs(), latest.getTs())) {
+ list.set(list.size() - 1, latest);
+ } else if (last.getTs() < latest.getTs()) {
+ list.add(latest);
+ }
+ }
+
+ /**
+ * 基于实时行情聚合当前周期未收盘 K 线(非加密货币等场景兜底)。
+ */
+ private void appendInProgressKline(List<Kline> list, String symbol, String line) {
+ Realtime realtime = DataCache.getLatestRealTime(symbol);
+ if (realtime == null) {
+ realtime = DataCache.getRealtime(symbol);
+ }
+ if (realtime == null) {
+ return;
+ }
+ Kline kline = null;
+ if (KlineConstant.PERIOD_1MIN.equals(line)) {
+ kline = klineService.bulidKline1Minute(realtime, KlineConstant.PERIOD_1MIN);
+ } else if (KlineConstant.PERIOD_5MIN.equals(line)) {
+ kline = klineService.bulidKline5Minute(realtime, KlineConstant.PERIOD_5MIN);
+ } else if (KlineConstant.PERIOD_15MIN.equals(line)) {
+ kline = klineService.bulidKline15Minute(realtime, KlineConstant.PERIOD_15MIN);
+ } else if (KlineConstant.PERIOD_30MIN.equals(line)) {
+ kline = klineService.bulidKline30Minute(realtime, KlineConstant.PERIOD_30MIN);
+ } else if (KlineConstant.PERIOD_60MIN.equals(line)) {
+ kline = klineService.bulidKline60Minute(realtime, KlineConstant.PERIOD_60MIN);
+ } else if (KlineConstant.PERIOD_4HOUR.equals(line)) {
+ kline = klineService.bulidKline4Hour(realtime, KlineConstant.PERIOD_4HOUR);
+ } else if (KlineConstant.PERIOD_1DAY.equals(line)) {
+ kline = klineService.bulidKline1Day(realtime, KlineConstant.PERIOD_1DAY);
+ } else if (KlineConstant.PERIOD_5DAY.equals(line)) {
+ kline = klineService.bulidKline5Day(realtime, KlineConstant.PERIOD_5DAY);
+ } else if (KlineConstant.PERIOD_1WEEK.equals(line)) {
+ kline = klineService.bulidKline1Week(realtime, KlineConstant.PERIOD_1WEEK);
+ } else if (KlineConstant.PERIOD_1MON.equals(line)) {
+ kline = klineService.bulidKline1Mon(realtime, KlineConstant.PERIOD_1MON);
+ } else if (KlineConstant.PERIOD_QUARTER.equals(line)) {
+ kline = klineService.bulidKline1Mon(realtime, KlineConstant.PERIOD_QUARTER);
+ } else if (KlineConstant.PERIOD_YEAR.equals(line)) {
+ kline = klineService.bulidKline1Mon(realtime, KlineConstant.PERIOD_YEAR);
+ }
+ if (kline != null) {
+ mergeLatestKline(list, kline);
+ }
+ }
+
@Override
public List<Trend> trend(String symbol) {
TrendTimeObject trendTimeObject = DataCache.getTrend(symbol);
--
Gitblit v1.9.3