Go中布尔表达式直接使用变量或逻辑运算符,无需与true/false比较;正确写法如if isReady、if !isValid;复合条件用括号明确优先级;避免冗余switch布尔判断。
Go 中布尔值就是 bool 类型,只有 true 和 false 两个值。直接拿布尔变量或表达式做条件判断即可,**不需要也不应该写成 if flag == true 或 if flag == false**——这既冗余又容易因赋值误写成 = 导致编译错误或逻辑 bug。
常见错误现象:if done = true { ... }(少了个 =),Go 编译器会报错 cannot assign to if condition;但更隐蔽的是在复合表达式中混用 = 和 ==。
if isReady { ... }、if !isValid { ... }
if (a > 0 && b
false 时,&& 后面不执行;左侧为 true 时,|| 后面不执行Go 不支持三元运算符(a ? b : c),所以多条件分支必须用 if / else if / else 显式写出。关键点在于:**条件表达式必须是纯布尔类型,不能是整数、指针或 nil 检查结果直接塞进 if**。
例如,if x 在 Go 中非法(x 是 int),而 if x != nil 才合法(x 是指针或 map/slice/channel)。
isValid := len(name) > 0 && strings.HasPrefix(name, "user_")
if isValid { ... }if 建议用卫语句(guard clause)提前 returnelse if 链中,Go 不会自动 fallthrough,每个分支独立,无需 break
Go 的 switch 默认支持布尔表达式,但**不是用来替代简单 if 的**。它的优势在于多个离散条件或类型判断,而非连续布尔组合。
错误用法:switch flag { case true: ... case false: ... } —— 这完全等价于 if flag { ... } else { ... },反而啰嗦。
switch {
case x > 10 && y < 5:
log.Println("high priority")
case x > 5 && y < 10:
log.Println("normal")
default:
log.Println("low")
}switch 中每个 case 是从上到下顺序匹配,第一个为 true 的就执行,后续不再检查case 就是独立布尔表达式
uct 里初始化要注意什么?Go 中未显式初始化的 bool 字段默认是 false,这点和其他零值类型一致。但问题常出在 JSON 解析或数据库映射时:
bool 字段仍为 false,无法区分“没传”和“传了 false”——需要改用 *bool 指针类型json:",omitempty" 对 bool 无效(因为 false 是零值,会被忽略),想保留 false 必须去掉 omitempty 或用指针bool 列时,NULL 值会转成 false,同样建议用 *bool 显式表达三态(true/false/nil)