From 2af15077fb2e66500e955ffebc44ecad42e2dd66 Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Tue, 19 May 2026 11:18:56 +0800
Subject: [PATCH] feat(ws): 添加订单更新ID日志记录功能
---
src/main/java/com/xcong/excoin/modules/gateApi/GridElement.java | 77 ++++++++++++++++++++++++++++++++++++++
1 files changed, 77 insertions(+), 0 deletions(-)
diff --git a/src/main/java/com/xcong/excoin/modules/gateApi/GridElement.java b/src/main/java/com/xcong/excoin/modules/gateApi/GridElement.java
index e34f80c..1287dd3 100644
--- a/src/main/java/com/xcong/excoin/modules/gateApi/GridElement.java
+++ b/src/main/java/com/xcong/excoin/modules/gateApi/GridElement.java
@@ -1,6 +1,7 @@
package com.xcong.excoin.modules.gateApi;
import java.math.BigDecimal;
+import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
@@ -153,6 +154,7 @@
INDEX.put(e.getId(), e);
putDynamicIndices(e);
}
+ logAll();
}
/**
@@ -170,6 +172,81 @@
for (GridElement e : INDEX.values()) {
putDynamicIndices(e);
}
+ logAll();
+ }
+
+ /**
+ * 打印全部网格数据到日志。
+ */
+ public static void logAll() {
+ List<GridElement> sorted = new ArrayList<>(INDEX.values());
+ sorted.sort((a, b) -> Integer.compare(a.getId(), b.getId()));
+ StringBuilder sb = new StringBuilder("\n========== 网格数据 ==========\n");
+ for (GridElement e : sorted) {
+ if (e.isHasLongOrder() || e.isHasShortOrder()){
+ sb.append(String.format(
+ " ID=%4d 价格=%s up=%s down=%s 多仓=%s(%s) 空仓=%s(%s) 多止盈=%s 空止盈=%s\n",
+ e.getId(),
+ e.getGridPrice(),
+ e.getUpId(),
+ e.getDownId(),
+ e.isHasLongOrder() ? "有" : "无",
+ e.getLongOrderId() != null ? e.getLongOrderId() : "-",
+ e.isHasShortOrder() ? "有" : "无",
+ e.getShortOrderId() != null ? e.getShortOrderId() : "-",
+ e.getLongTakeProfitOrderId() != null ? e.getLongTakeProfitOrderId() : "-",
+ e.getShortTakeProfitOrderId() != null ? e.getShortTakeProfitOrderId() : "-"
+ ));
+ }
+ }
+ sb.append(String.format(
+ "------------------------------------------------------------\n" +
+ " 索引统计: ID=%d 价格=%d 多仓订单ID=%d 空仓订单ID=%d 多止盈ID=%d 空止盈ID=%d\n",
+ INDEX.size(),
+ PRICE_INDEX.size(),
+ LONG_ORDER_ID_INDEX.size(),
+ SHORT_ORDER_ID_INDEX.size(),
+ LONG_TP_ORDER_ID_INDEX.size(),
+ SHORT_TP_ORDER_ID_INDEX.size()
+ ));
+ sb.append(String.format(" 多仓订单ID索引: %s\n", LONG_ORDER_ID_INDEX.keySet()));
+ sb.append(String.format(" 空仓订单ID索引: %s\n", SHORT_ORDER_ID_INDEX.keySet()));
+ sb.append(String.format(" 多止盈ID索引: %s\n", LONG_TP_ORDER_ID_INDEX.keySet()));
+ sb.append(String.format(" 空止盈ID索引: %s\n", SHORT_TP_ORDER_ID_INDEX.keySet()));
+ sb.append("================================\n");
+ System.out.println(sb);
+ }
+
+ /**
+ * 获取所有已挂多仓条件单的网格元素。
+ * 小于空仓仓位线的多单
+ *
+ * @return 已挂多仓条件单的 GridElement 列表
+ */
+ public static List<GridElement> findAllLongOrders(BigDecimal currentPrice) {
+ List<GridElement> result = new ArrayList<>();
+ for (GridElement e : INDEX.values()) {
+ if (e.isHasLongOrder() && e.getGridPrice().compareTo(currentPrice) < 0) {
+ result.add(e);
+ }
+ }
+ return result;
+ }
+
+ /**
+ * 获取所有已挂空仓条件单的网格元素。
+ * 大于多仓仓位线的空单
+ *
+ * @return 已挂空仓条件单的 GridElement 列表
+ */
+ public static List<GridElement> findAllShortOrders(BigDecimal currentPrice) {
+ List<GridElement> result = new ArrayList<>();
+ for (GridElement e : INDEX.values()) {
+ if (e.isHasShortOrder() && e.getGridPrice().compareTo(currentPrice) < 0) {
+ result.add(e);
+ }
+ }
+ return result;
}
private static void putDynamicIndices(GridElement e) {
--
Gitblit v1.9.1