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
}
有些小子对如何编写不同的条件有意见。 条件的两个最重要的参数是golint
和gocritic
。
删除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
}