Go通过const+iota实现枚举,iota是const块内从0开始的行号计数器;可跳过值(_ = iota)、调整起始值(iota + N)、生成位掩码(1
Go 没有原生 enum 关键字,但用 const + iota 组合就能安全、简洁、可维护地实现枚举效果。核心在于理解 iota 是 const 块内的“行号计数器”,从 0 开始,每行自动 +1,且每个 const 块独立重置。
最常见场景是定义一组连续整数常量,比如星期、状态码、颜色等。
iota 在 const 块首行默认为 0,后续每行隐式 +1io
ta)int、uint8)示例:
const (
Sunday = iota // 0
Monday // 1
Tuesday // 2
Wednesday // 3
)实际业务中常需避开 0(因 0 可能表示“未初始化”),或跳过某些无效值。
_ = iota 占位跳过某值,不导出也不参与逻辑iota + N 调整起始偏移,如从 1 开始示例(从 1 开始,跳过 0):
const (
_ = iota // 跳过 0
Active // 1
Inactive // 2
Pending // 3
)利用 iota 参与表达式,适合定义标志位(flags)、权限位、二进制掩码等。
1 生成 1, 2, 4, 8…(即 2⁰, 2¹, 2²…)iota * 10、iota + 100、iota % 3 等iota 值示例(位标志):
const (
Read = 1 << iota // 1
Write // 2
Execute // 4
Admin // 8
)这样 Read | Execute 就是合法组合值 5。
真实项目中应避免裸 int 枚举,推荐封装为自定义类型并实现 String() 方法提升可读性。
const 块内 iota 独立重置,适合分组定义type Status int)约束变量取值范围String() string,方便日志和调试示例:
type Status intconst ( Unknown Status = iota // 0 OK // 1 Error // 2 Timeout // 3 )
func (s Status) String() string { switch s { case Unknown: return "unknown" case OK: return "ok" case Error: return "error" case Timeout: return "timeout" default: return "status?" } }
基本上就这些。iota 不是语法糖,而是编译期确定的行计数机制,写对了很省心,写错了也容易排查——关键就是盯住“块内行号”这个本质。