不会,strconv.Atoi 从不 panic,但会返回 error;它仅支持十进制整数字符串(可带 ±),对空串、非数字字符、超范围值等均返回非 nil error,必须显式检查。

strconv.Atoi 会 panic 吗?不会,但返回 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
为什么不用 Atoi 而选 ParseInt?精度和进制控制需求
当需要明确指定位宽(如 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 - 第 3 个参数不能为 0(除非你真想依赖平台 int 大小),否则可能在 32 位环境意外溢出
strconv.Itoa 是最简整数转字符串,但不支持进制或格式化
strconv.Itoa 是 string(int) 的安全封装,仅适用于十进制、无符号/有符号整数转字符串,底层调用 FormatInt(int64(i), 10)。它**不支持自定义进制、补零、对齐等格式需求**。
-
strconv.Itoa(255)→"255" -
strconv.Itoa(-42)→"-42" - 想转十六进制?用
strconv.FormatInt(int64(x), 16) - 想补零到 4 位?得组合
fmt.Sprintf("%04d", x)或手动 pad - 传入
float64会编译失败:它只接受int类型,不是泛型函数
s := strconv.Itoa(123) fmt.Println(s) // "123"
容易被忽略的边界:Unicode 数字、科学计数法、+0/-0
strconv.Atoi 和 ParseInt **只认 ASCII 数字字符 '0'–'9'**,不识别全角数字、罗马数字或 Unicode 数字(如阿拉伯文数字)。同时,它们**完全不支持科学计数法**(如 "1e3"),那属于 strconv.ParseFloat 的范畴。
立即学习“go语言免费学习笔记(深入)”;
-
"١٢٣"(阿拉伯数字)→ 解析失败 -
"1e3"→invalid syntax,不是数值范围问题,是语法不匹配 -
"+0"和"-0"都能成功解析为0,但注意:负零在整数中无区别,只是字符串形态 - 超大数如
"999999999999999999999"在ParseInt(..., 64)下会返回strconv.ErrRange,需显式判断
Atoi 成为默认选择,也别把 Itoa 当万能格式化工具。










