Closed. This question is opinion-based。它当前不接受答案。
想改善这个问题吗?更新问题,以便editing this post用事实和引用来回答。
在16天前关闭。
Improve this question
是否有官方的Go风格指南来描述是否将代码放在then子句之后并返回else子句?
换句话说,以下两个选项中的一个或另一个是否规范?
使用其他:
想改善这个问题吗?更新问题,以便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
}
关于if-statement - 在then子句之后使用或不使用else子句,该子句返回[closed],我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/63868594/
10-15 03:10