Go中const声明的常量在编译期确定、运行时不可修改且不分配内存地址;支持无类型推导和显式类型声明,后者可避免隐式转换问题;iota用于const块内自增枚举,每块重置为0,支持运算与占位。

const 声明常量的基本写法
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
解决方法是显式带类型声明:
立即学习“go语言免费学习笔记(深入)”;
const timeout int32 = 5000 const pi float64 = 3.14159 const enabled bool = true
iota 在 const 块中自增枚举
iota 是 Go 内置的“枚举计数器”,只在 const 块中有效,每行自增 1(从 0 开始)。常用在状态码、标志位定义中:
const (
StatusOK = iota // 0
StatusNotFound // 1
StatusBadRequest // 2
StatusInternalServerError // 3
)注意几个易错点:
-
iota每次进入新const块重置为 0,不是全局连续 - 某行没写表达式时,会复用上一行的值(包括
iota表达式) - 想跳过某值,可用下划线占位:
_ = iota - 支持运算:
FlagRead = 1 可生成位掩码
const 块中混合声明与作用域限制
一个 const 块可同时声明不同类型常量,但不能混入变量或函数调用:
const (
appName = "myapp"
appPort = 8080
isDebug = false
// logLevel = getLogLevel() // ❌ 编译错误:右值必须是编译期常量
)另外,常量作用域遵循 Go 的常规规则:
- 包级
const小写首字母为私有(仅本包可见) - 大写首字母导出,其他包可通过
import使用 - 函数内不能声明
const—— 这和 C/C++ 不同,Go 不允许局部常量
真正需要“运行时常量”的场景(比如依赖环境变量初始化的值),得用 var + init() 或惰性加载,const 做不到。










