

新闻资讯
技术学院优先选 int64 保证跨平台一致性,仅索引等小范围场景用 int;float64 为默认,大规模数组且精度可接受时才选 float32;修改内容用 []byte,只读用 string;状态用 bool 或自定义 error/enum 类型。
int 还是 int64?看运行环境和边界需求Go 的 int 是平台相关类型:在 64 位系统上通常是 64 位,在 32 位系统上是 32 位。这会导致跨平台编译或部署时行为不一致,比如在某些 CI 环境(如 ARM32 容器)中 int 溢出而本地开发没发现。
int64
int,但需确保不参与跨平台序列化或网络传输int 接收 len() 结果后直接赋给 int32 变量,会触发截断警告或 panic(开启 -race 或使用 go vet 可捕获)float64 是默认选择,float32 要主动权衡精度与内存Go 中字面量如 3.14 默认是 float64,且标准库函数(如 math.Sin、time.Since 返回值)也统一用 float64。盲目换 float32 不仅可能引入舍入误差,还常因隐式转换导致编译失败。
float64
float32 节省内存(约减半)和缓存压力float32(1.0) + 2.0 会报错,因为 2.0 是 float64,类型不匹配[]byte 可改 —— 别误用 string 做缓冲区把 string 当可写缓冲区(比如反复拼接、逐字节修改)是常见性能陷阱。每次 + 都分配新字符串,string 转 []byte 会产生底层数组拷贝(除非用 unsafe.String,但属非安全操作)。
[]byte,配合 bytes.Buffer 或预分配切片string,零拷贝传递更高效[]byte 构造 string 时注意:若 byte slice 后续会被修改,应拷贝一份再转,否则 string 内容可能意外变化(底层共用底层数组)bool 和 error 类型语义更清晰有些 C/Python 背景开发者习惯用 int 表示开关(0 / 1)或错误码(-1),但在 Go 中这破坏类型安全,也绕过 if err != nil 的惯用法。
bool,避免 if flag == 1 这类易错写法error 类型,成功与否由 err 判断,而非返回 int 码值type Status int + const,而不是复用 int
type Status int
const (
Pending Status = iota
Success
Failed
)
func (s Status) String() string {
switch s {
case Pending: return "pending"
case Success: return "success"
case Failed: return "failed"
defa
ult: return "unknown"
}
}
Go 的类型选择不是“够用就行”,而是“意图即契约”。一个 int64 参数意味着调用方必须提供 64 位安全的值,一个 string 字段意味着它绝不会被原地修改。忽略这点,后期重构或并发场景下容易暴露隐蔽 bug。