strconv.Atoi panic 是因未检查错误,它仅支持纯数字字符串,空格、字母、符号或空串均返回 error;正确用法必须显式处理 err。

strconv.Atoi 转字符串为整数时为什么 panic?
strconv.Atoi 只接受纯数字字符串,遇到空格、字母、符号或空字符串会直接返回 error,但很多人忽略错误检查,导致程序 panic。它本质是 strconv.ParseInt(s, 10, 0) 的封装,底层不处理边界和格式容错。
- 正确用法必须检查返回的
error:num, err := strconv.Atoi("123") if err != nil { log.Fatal(err) } // num 是 int 类型 - 常见错误输入:
" 123"(前导空格)、"12.3"(小数点)、""(空串)、"abc"—— 全部返回非 nil 错误 - 如果需要容忍空格,先用
strings.TrimSpace预处理;若需支持浮点字符串转整,应先用strconv.ParseFloat再类型转换
ParseInt 和 ParseUint 的 bitSize 参数怎么选?
Go 是强类型语言,int 在不同平台可能是 32 或 64 位,而 strconv.ParseInt 的第三个参数 bitSize 必须显式指定目标整数宽度,否则无法匹配 Go 类型系统。
- 想转成
int64:用strconv.ParseInt(s, 10, 64) - 想转成
int32:用strconv.ParseInt(s, 10, 32) - 想转成 Go 默认的
int:不能直接写0或省略 —— 必须根据目标平台判断,更稳妥的是统一用64,再手动转:n64, _ := strconv.ParseInt(s, 10, 64) n := int(n64) // 注意溢出风险
-
ParseUint同理,但只接受无符号数,传入负号如"-5"会报strconv.ParseUint: parsing "-5": invalid syntax
Itoa 和 FormatInt 有什么区别?
strconv.Itoa 是最简捷的 int → string 转换,但它只支持 int 类型;而 strconv.FormatInt 支持任意有符号整数(如 int64),且可指定进制。
-
strconv.Itoa(42)等价于strconv.FormatInt(int64(42), 10),仅限十进制int - 要转十六进制:
strconv.FormatInt(255, 16)→"ff";八进制:strconv.FormatInt(255, 8)→"377" - 如果变量是
int32或int64,别硬套Itoa,会编译失败 —— 必须用FormatInt(int64(x), 10)显式转换 -
FormatUint用于uint64等无符号类型,不接受负值
float 转换中精度丢失和 NaN 处理容易被忽略
strconv.ParseFloat 和 strconv.FormatFloat 涉及 IEEE 754 浮点表示,转换不是精确映射,尤其对小数部分(如 0.1)和大整数(超过 2^53)极易出偏差。
-
strconv.ParseFloat("0.1", 64)返回的float64值实际是近似值,后续比较请用误差范围而非== - 输入为
"NaN"、"Inf"、"-Inf"时,ParseFloat会成功返回对应浮点特殊值,但很多业务逻辑没做math.IsNaN或math.IsInf检查 -
FormatFloat的第四参数prec控制小数位数,设为-1表示“最短有效表示”,设为6是默认 float64 输出精度,但不等于保留 6 位小数 —— 它是总有效数字位数 - 若需固定小数位(如金额),不要依赖
FormatFloat,改用fmt.Sprintf("%.2f", x)或专用 decimal 库
"strconv.Atoi: parsing \"\": invalid syntax",第一反应不该是补 if s == "",而是追查上游为什么传了空字符串。










