gpt4 book ai didi

java - 以 Java 方式返回具有多个值的结果

转载 作者:IT老高 更新时间:2023-10-28 21:02:01 24 4
gpt4 key购买 nike

我习惯使用 Python 进行开发,但由于工作原因不得不使用 Java。我正面临一个在 Python 中微不足道的任务,我想要一些关于如何在 Java 中以正确方式处理这个问题的建议。

我需要解析一个持续时间字符串。它可以以毫秒 (235ms) 或秒 (32s) 为单位。也可以是“< 1ms”作为特例。

解析在代码中至少发生了 3 次,所以我想将它分成一个方法。但是我的代码确实需要知道,不仅仅是以 ms 为单位的结果值,还需要知道它是以 ms 还是 s 以及是否 <1ms(0 是不同的值)。

在 Python 中,我只返回一个元组:

return (value_in_milliseconds,is_in_seconds,is_under_1ms)

在 C 中,我会定义这三个值的结构并返回它。在 Pascal 中,我会定义一个记录。

在 Java 中,我无法返回元组,也无法定义记录,我该怎么办?

我唯一能想到的就是创建一个表示持续时间值的类。构造函数将获取字符串并解析它。该类将具有以下字段:int 毫秒, boolean inSeconds, boolean 值低于 1ms。

但这听起来非常重量级 - 有更好的解决方案吗?

最佳答案

不要传递一组标志,这些标志必须在它们之间保持一致才能形成合理的状态。如果 is_in_secondsis_under_1ms 都是 true 怎么办?为什么包含单词 milliseconds 的变量会被解释为秒?在代码中看起来多么错误。如果你能做任何事情,看起来错误的代码是不好的——我们应该编写正确/错误的外观与现实相符的代码——最小惊讶原则应用于代码,甚至可能是后续的成功坑开发者的大脑会为此爆炸。

这听起来可能有点像 Primitive Obsession代码气味/反模式,可能来自您的 Python 背景? (我对 Python 几乎一无所知,所以请随意忽略这个猜测。)

解决方案:制作一个真正的领域级对象,表示近似持续时间的概念。

一种可能的实现方式:

  1. 创建一个 DurationScale 枚举,该枚举具有成员 SecondMillisecondSubMillisecond

  2. 创建一个类 ApproximateDuration,它接受一个 duration 整数和一个 durationScale 枚举值。

  3. 现在在你的其他代码中使用这个对象。如果您需要总结一系列这些持续时间,请创建一个知道如何解释每个持续时间并将它们加在一起的类。或者给这个类添加方法。

DurationScale 等概念的替代方案可以是 MarginOfError,它本身可以用任意毫秒数表示。当您将不同的 ApproximateDuration 对象相加成一个新的 ApproximateDuration 对象时,这可以让您使用严格的数学公式来适本地增加误差范围。

注意:你可以看到一些 further discussion关于我为什么推荐这种方法。

您确定的实现也是一种处理它的好方法,您可以明确说明下限和上限:

public final class ApproximateDuration {
private final int lowMilliseconds;
private final int highMilliseconds;

public ApproximateDuration(int lowMilliseconds, int highMilliseconds) {
this.lowMilliseconds = lowMilliseconds;
this.highMilliseconds = highMilliseconds;
}

public int getLowMilliseconds() {
return lowMilliseconds;
}

public int getHighMilliseconds() {
return highMilliseconds;
}
}

请注意,将 Milliseconds 这个词放在变量和属性名称中很重要,这个类的不变性也很重要。

关于java - 以 Java 方式返回具有多个值的结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43619566/

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