Closed. This question is opinion-based。它当前不接受答案。












想改善这个问题吗?更新问题,以便editing this post用事实和引用来回答。

在16天前关闭。



Improve this question




是否有官方的Go风格指南来描述是否将代码放在then子句之后并返回else子句?
换句话说,以下两个选项中的一个或另一个是否规范?
使用其他:
func IsLeapYear(year int) bool {
  if year%400 == 0 {
    return true
  } else if year%100 == 0 {
    return false
  } else if year%4 == 0 {
    return true
  } else {
    return false
  }
}
不要使用其他:
func IsLeapYear(year int) bool {
  if year%400 == 0 {
    return true
  }
  if year%100 == 0 {
    return false
  }
  if year%4 == 0 {
    return true
  }
  return false
}

最佳答案

有些小子对如何编写不同的条件有意见。 条件的两个最重要的参数是golintgocritic
删除else

    if cond1 {
        return true
    } else {
        return false
    }
golint建议删除else:
    if cond1 {
        return true
    }
    return false
改用switch
func IsLeapYear(year int) bool {
  if year%400 == 0 {
    return true
  } else if year%100 == 0 {
    return false
  } else if year%4 == 0 {
    return true
  } else {
    return false
  }
}
在这种情况下,gocritic将告诉您使用switch语句。 AFAIK会在if .. else if .. else语句中有3个或更多案例时立即这样做。
func IsLeapYear(year int) bool {
    switch {
    case year%400 == 0:
        return true
    case year%100 == 0:
        return false
    case year%4 == 0:
        return true
    }
    return false
}
一种情况的switch
    switch {
    case year%400 == 0:
        return true
    }
这里gocritic突然出现,让我们知道它更喜欢简单的if语句:
    if year%400 == 0 {
        return true
    }

关于if-statement - 在then子句之后使用或不使用else子句,该子句返回[closed],我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/63868594/

10-15 03:10