gpt4 book ai didi

Java - 如何比较 Guava 范围?

转载 作者:行者123 更新时间:2023-11-30 06:42:46 25 4
gpt4 key购买 nike

我决定创建一个 Map 来存储指标名称和代表每个指标生命周期的范围。起初,我使用 TreeRangeMap 来存储范围,但由于每个指标都包含一个范围,所以我切换到范围,如下所示。

我的目标是当我从外部 API 收到指标的 Range 时,在 DEFAULT_METRICS_MAP 中保留最新的时间范围。当我有一个代表范围的 TreeRangeMap 时,比较它们很容易。我向 TreeRangeMap 添加了新的指标,然后得到了这样的最大范围:

private static Optional<Range<Long>> maxRange(TreeRangeSet<Long> rangeSet) {
Set<Range<Long>> ranges = rangeSet.asRanges();
return ranges.stream().max(Comparator.comparing(Range::upperEndpoint));
}

当范围未包装到 TreeRangeMap 中时,比较范围的正确方法是什么?

public static final Map<String, Range<Long>> DEFAULT_METRICS_MAP;
static {
Map<String, Range<Long>> theMap = new HashMap<>();
theMap.put("Metric1", Range.closed(Long.MIN_VALUE, Long.MAX_VALUE));
theMap.put("Metric2", Range.closed(10L, 20L));
theMap.put("Metric3", Range.closed(30L, 50L));
METRICS_MAP = Collections.unmodifiableMap(theMap);
}

最佳答案

首先,在这种特殊情况下避免使用 TreeRangeMap/TreeRangeSet 是一个正确的决定。据我了解(如果我错了请纠正我),您不需要保留所有指标的所有范围。您需要的是每时每刻每个指标的最新范围。理想情况下,您希望有一种非常快速的检索方法,例如:

Range<Long> range = getRange(metric);

最有效的方法是在接收到 Range 对象时比较它们:

public void setRange(String metric, Range<Long> newRange) {
Range<Long> oldRange = metricRanges.get(metric);
if (comparator.compare(newRange, oldRange) > 0) {
metricRanges.put(metric, newRange);
}
}

这里是完整的例子:

// Better keep this map encapsulated
private final Map<String, Range<Long>> metricRanges = new HashMap<>();

private final Comparator<Range<Long>> comparator =
Comparator.nullsFirst(Comparator.comparing(Range::upperEndpoint));

static {
// Fill in your map with default ranges
}

public void setRange(String metric, Range<Long> newRange) {
Range<Long> oldRange = metricRanges.get(metric);
if (comparator.compare(newRange, oldRange) > 0) {
metricRanges.put(metric, newRange);
}
}

public Range<Long> getRange(String metric) {
return metricRanges.get(metric);
}

如果你还需要Optional:

public Optional<Range<Long>> getRange(String metric) {
return Optional.of(metricRanges.get(metric));
}

关于Java - 如何比较 Guava 范围?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53066231/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com