gpt4 book ai didi

java - 如何降低返回月份名称的方法的圈复杂度?

转载 作者:行者123 更新时间:2023-11-30 03:12:35 25 4
gpt4 key购买 nike

有一个metrics plugin在 eclipse 中测量 cyclomatic complexity通过计算决策(独立路径),具体来说:

 (if, for, while, do, case, catch and the ?: ternary operator, as well as the && and || conditional logic operators in expressions)

例如,这是一个得分为 14 的方法。(1 + 每个决策路径)

  String getMonthName (int month) {
switch (month) {
case 0: return "January";
case 1: return "February";
case 2: return "March";
case 3: return "April";
case 4: return "May";
case 5: return "June";
case 6: return "July";
case 7: return "August";
case 8: return "September";
case 9: return "October";
case 10: return "November";
case 11: return "December";
default: throw new IllegalArgumentException();
}
}

我想知道是否有一种方法可以在没有提到的java分支的情况下做出决定,这会破坏评估。基本上,我希望在插件不检测到它们的情况下做出不同的决定。这些指标将显示比实际更低的圈复杂度(独立路径/决策)。

最佳答案

为了降低圈复杂度,您应该解耦代码或重构代码以获得更好的实现。

对于提供的示例,您可以使用数组:

static final String[] MONTHS = {"January", "February", ... };
static String getMonthName(int month) {
if (month < 0 || month >= MONTHS.length) {
throw new IllegalArgumentException(String.format("Month %d doesn't exist", month));
}
return MONTHS[month];
}

即使是上面的方法也可以进一步解耦:

static final String[] MONTHS = {"January", "February", ... };
static String getMonthName(int month) {
checkBoundaries(month, 0, MONTHS.length - 1, String.format("Month %d doesn't exist", month));
return MONTHS[month];
}
static void checkBoundaries(int n, int lowerBound, int upperBound, String errorMessage) {
if (n < lowerBound || n > upperBound) {
throw new IllegalArgumentException(errorMessage);
}
}

关于java - 如何降低返回月份名称的方法的圈复杂度?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33309839/

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