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 对布尔值的支持非常严格,只认几个固定字符串:
立即学习“go语言免费学习笔记(深入)”;
-
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。










