strconv.Atoi panic 是因未检查错误,它仅支持纯数字字符串,空格、字母、符号或空串均返回 error;正确用法必须显式处理 err。
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 再类型转换Go 是强类型语言,int 在不同平台可能是 32 或 64 位,而 strconv.ParseInt 的第三个参数 bitSize 必须显式指定目标整数宽度,否则无法匹配 Go 类型系统。
int64:用 strconv.ParseInt(s, 10, 64)
int32:用 strconv.ParseInt(s, 10, 32)
int:不能直接写 0 或省略 —— 必须根据目标平台判断,更稳妥的是统一用 64,再手动转:n64, _ := strconv.ParseInt(s, 10, 64) n := int(n64) // 注意溢出风险
ParseUint 同理,但只接受无符号数,传入负号如 "-5" 会报 strconv.ParseUint: parsing "-5": invalid syntax
strconv.Itoa 是最简捷的 int → string 转换,但它只支持 int 类型;而 strconv.FormatInt 支持任意有符号整数(如 int64),且可指定进制。
strconv.Itoa(42) 等价于 strconv.FormatInt(int64(42), 10),仅限十进制 int
strconv.FormatIn
t(255, 16) → "ff";八进制:strconv.FormatInt(255, 8) → "377"
int32 或 int64,别硬套 Itoa,会编译失败 —— 必须用 FormatInt(int64(x), 10) 显式转换FormatUint 用于 uint64 等无符号类型,不接受负值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 == "",而是追查上游为什么传了空字符串。