不会,strconv.Atoi 从不 panic,但会返回 error;它仅支持十进制整数字符串(可带 ±),对空串、非数字字符、超范围值等均返回非 nil error,必须显式检查。
strconv.Atoi 看似简单,实际调用后必须检查 error,它**从不 panic**,但只要字符串含非数字字符(如空格、字母、符号)、为空或超出 int 范围,就会返回非 nil 的 error。常见错误是忽略返回的 err,直接用转换结果,导致逻辑错乱却无报错提示。
+ 或 -,但不支持 0x(十六进制)、0o(八进制)、0b(二进制)前缀"" → strconv.Atoi: parsing "": invalid syntax
"123abc" → strconv.Atoi: parsing "123abc": invalid syntax
" 123"(带空格)→ 同样报错;需先 strings.TrimSpace
num, err := strconv.Atoi("42")
if err != nil {
log.Fatal(err) // 不要忽略 err
}
fmt.Println(num) // 42
当需要明确指定位宽(如 int64)、进制(如十六进制字符串 "ff")、或处理可能超 int 范围的大数时,strconv.Atoi 就不够用了——它等价于 ParseInt(s, 10, 0),其中 0 表示“用当前平台 int 位宽”,不可控且易出兼容问题(32 位 vs 64 位系统)。
strconv.ParseInt("9223372036854775807", 10, 64) → 安全转 int64
strconv.ParseInt("ff", 16, 64) → 得到 255
strconv.ParseInt("1111", 2, 64) → 得到 15
strconv.Itoa 是 string(int) 的安全封装,仅适用于十进制、无符号/有符号整数转字符串,底层调用 FormatInt(int64(i), 10)。它**不支持自定义进制、补零、对齐等格式需求**。
strconv.Itoa(255) → "255"
strconv.Itoa(-42) → "-42"
strconv.FormatInt(int64(x), 16)
fmt.Sprintf("%04d", x) 或手动 padfloat64 会编译失败:它只接受 int 类型,不是泛型函数s := strconv.Itoa(123) fmt.Println(s) // "123"
strconv.Atoi 和 ParseInt **只认 ASCII 数字字符 '0'–'9'**,不识别全角数字、罗马数字或 Unicode 数字(如阿拉伯文数字)。同时,它们**完全不支持科学计数法**(如 "1e3"),那属于 strconv.ParseFloat 的范畴。
"١٢٣"(阿拉伯数字)→ 解析失败"1e3
" → invalid syntax,不是数值范围问题,是语法不匹配"+0" 和 "-0" 都能成功解析为 0,但注意:负零在整数中无区别,只是字符串形态"999999999999999999999" 在 ParseInt(..., 64) 下会返回 strconv.ErrRange,需显式判断Atoi 成为默认选择,也别把 Itoa 当万能格式化工具。