Go通过const+iota实现枚举,iota是const块内从0开始的行号计数器;可跳过值(_ = iota)、调整起始值(iota + N)、生成位掩码(1

Go 没有原生 enum 关键字,但用 const + iota 组合就能安全、简洁、可维护地实现枚举效果。核心在于理解 iota 是 const 块内的“行号计数器”,从 0 开始,每行自动 +1,且每个 const 块独立重置。
基础用法:自增整数枚举
最常见场景是定义一组连续整数常量,比如星期、状态码、颜色等。
-
iota在 const 块首行默认为 0,后续每行隐式 +1 - 未显式赋值的常量会自动继承上一行的表达式(含
iota) - 类型可省略(无类型整数),也可显式指定(如
int、uint8)
示例:
const (
Sunday = iota // 0
Monday // 1
Tuesday // 2
Wednesday // 3
)控制起始值与跳过项
实际业务中常需避开 0(因 0 可能表示“未初始化”),或跳过某些无效值。
立即学习“go语言免费学习笔记(深入)”;
- 用
_ = 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。
多 const 块与类型封装(工程实践建议)
真实项目中应避免裸 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 不是语法糖,而是编译期确定的行计数机制,写对了很省心,写错了也容易排查——关键就是盯住“块内行号”这个本质。










