Go中const声明的常量在编译期确定、运行时不可修改且不分配内存地址;支持无类型推导和显式类型声明,后者可避免隐式转换问题;iota用于const块内自增枚举,每块重置为0,支持运算与占位。
Go 里用 const 声明的值在编译期就确定,运行时不可修改,也**不分配内存地址**(除非被取地址或逃逸到堆上)。最简写法就是直接赋值:
const pi = 3.14159 const version = "v1.2.0" const maxRetries = 3
Go 会根据右侧字面量自动推导类型。但要注意:这种“无类型常量”在参与运算或赋值时可能隐式转换,容易掩盖类型意图。
当常量用于强类型上下文(比如函数参数、结构体字段),不显式声明类型可能导致编译失败或意外截断。例如:
const timeout = 5000 // 无类型整数 var d time.Duration = timeout * time.Millisecond // ✅ OK:自动转为 int var x int32 = timeout // ❌ 编译错误:不能把无类型 int 赋给 int32
解决方法是显式带类型声明:
const timeout int32 = 5000 const pi float64 = 3.14159 const enabled bool = true
string 类型可防止被误当作 []byte 处理iota 是 Go 内置的“枚举计数器”,只在 const 块中有效,每行自增 1(从 0 开始)。常用在状态码、标志位定义中:
const (
StatusOK = iota // 0
StatusNotFound // 1
StatusBadRequest // 2
StatusInternalServerError // 3
)注意几个易错点:
iota 每次进入新 const 块重置为 0,不是全局连续iota 表达式)_ = iota
FlagRead = 1 可生成位掩码
一个 const 块可同时声明不同类型常量,但不能混入变量或函数调用:
const (
appName = "myapp"
appPort = 8080
isDebug =
false
// logLevel = getLogLevel() // ❌ 编译错误:右值必须是编译期常量
)另外,常量作用域遵循 Go 的常规规则:
const 小写首字母为私有(仅本包可见)import 使用const —— 这和 C/C++ 不同,Go 不允许局部常量真正需要“运行时常量”的场景(比如依赖环境变量初始化的值),得用 var + init() 或惰性加载,const 做不到。