Go 的 strconv 包不支持双向自动转换,所有转换必须显式调用函数且需检查错误;字符串转数字需按进制、类型、精度选 Atoi/ParseInt/ParseFloat;数字转字符串应避免 Itoa 误用,优先 FormatInt/FormatFloat;布尔值仅支持固定字符串互转;字节切片与字符串用类型转换而非 strconv。
Go 的 strconv 包不支持直接“双向自动转换”,所有转换都必须显式调用对应函数,且失败时返回错误而非 panic —— 这是它和 Python 或 JavaScript 的根本区别。
Atoi、ParseInt、ParseFloat 要分清场景别一上来就用 Atoi,它只是 ParseInt(s, 10, 0) 的快捷封装,只处理十进制整数且固定为 int 类型(底层依赖运行时架构)。遇到以下情况必须换函数:
Atoi 解析 "123.45" 直接报错:strconv.Atoi: parsing "123.45": invalid syntax
"0xFF")或八进制,得用 ParseInt(s, 16, 64),第二个参数是进制基数"3.14159"),必须用 ParseFloat(s, 64),第二个参数是精度(32 或 64)"9223372036854775808")超出 int64 范围时,ParseInt 返回 strconv.ErrRange,需检查错误而非忽略num, err := strconv.ParseInt("FF", 16, 64)
if err != nil {
log.Fatal(err) // 输出: strconv.ParseInt: parsing "FF": invalid syntax(注意:没加 "0x" 前缀会失败)
}
// 正确写法是 "0xFF" 或直接传 "FF" + 显式指定 base=16
Itoa,但注意它只接受 int
Itoa 是最常用也最省心的整数转字符串方法,但它**只接收 int 类型**。如果你有 int64、uint32 或 float64,不能强转再传 —— Go 不允许隐式类型转换:
strconv.Itoa(int(myInt64)) 在 32 位系统上可能截断数据(int 可能只有 32 位)FormatInt(i, 10)(整数)或 FormatFloat(f, 'g', -1, 64)(浮点数)FormatFloat 第三个参数控制小数位数:-1 表示自动选择最短表示(如 1.0 → "1"),5 表示固定 5 位(1.0 → "1.00000")s := strconv.FormatInt(12345, 10) // "12345" s = strconv.FormatInt(-123, 16) // "-7b" s = strconv.FormatFloat(3.14159, 'f', 2, 64) // "3.14"
ParseBool 和 FormatBool,不支持自定义字符串strconv 对布尔值的支持非常严格,只认几个固定字符串:
ParseBool("1")、ParseBool("t")、ParseBool("T")、ParseBool("true")、ParseBool("TRUE") → true
ParseBool("0")、ParseBool("f")、ParseBool("F")、ParseBool("false") → false
"yes"、"on"、"是")都会返回 strconv.ErrSyntax
FormatBool 固定输出 "true" 或 "false" 小写,无法改成 "1"/"0" —— 如需这种格式,得自己写 map[bool]string 或三元表达式[]byte)和字符串互转:别用 strconv,用类型转换strconv **完全不提供 []byte ↔ string 的转换函数**。这是常见误区。Go 中这两者转换是零拷贝的强制类型转换:
string(b) 把字节切片转成字符串(安全,只要 b 是有效 UTF-8 或你明确接受非 UTF-8
[]byte(s) 把字符串转成字节切片(会分配新底层数组,原字符串内容不可变)strconv.AppendXXX 系列(如 AppendInt)是往 []byte 末尾追加字符串形式的数字,不是类型转换s := "hello" b := []byte(s) // 正确:直接类型转换 s2 := string(b) // 正确 // 错误示例(编译不过): // strconv.ToString(b) // no such function // strconv.FromBytes(b) // no such function
真正容易被忽略的是:所有 ParseXxx 函数都返回 (T, error),而很多人只取第一个返回值,把错误丢掉;一旦输入不可控(比如 HTTP 查询参数、配置文件读取),程序就会在不该失败的地方静默出错或 panic(如果后续对零值做运算)。务必检查 err。