Go中类型转换错误需分 strconv 字符串转换和接口类型断言两类处理:前者用 Atoi/ParseInt/ParseFloat 并检查 error;后者用 v, ok := iface.(T) 安全断言,禁用强制转换语法。
在 Go 中处理类型转换错误,核心是区分两种常见场景:字符串与基本类型的互转(用 strconv 包),以及接口值到具体类型的转换(用类型断言)。两者错误机制不同,需分别应对。
strconv 中的转换函数(如 Atoi、ParseInt、ParseFloat)都返回 (T, error) 形式。错误通常来自格式非法(如 "12a")、超出范围(如 "99999999999999999999")或位宽不匹配。必须检查 error,不能忽略。
strconv.Atoi(s) 简洁转 int,它本质是 ParseInt(s, 10, 0)

ParseInt(s, base, bitSize),例如解析 16 进制数:ParseInt("ff", 16, 64)
ParseFloat(s, bitSize),注意 bitSize=64 对应 float64,32 对应 float32
fmt.Sscanf 替代——它不报错而是静默失败,难以调试Go 的空接口 interface{} 或自定义接口变量在运行时可能存任意类型。直接强制转换会 panic,必须用带 ok 的类型断言:
v, ok := interfaceVar.(TargetType),ok 为 true 表示成功if s, ok := data["name"].(string); ok { ... }
switch v := interfaceVar.(type) 类型开关更清晰类型转换不是“强制转型”,Go 没有 C 风格的强制类型转换语法。以下写法都是错的或危险的:
int("123") —— 这是函数调用语法,实际调用的是 int 类型的构造,但 string 不能直接转 int;编译失败myInt := (int)(myString) —— Go 不支持括号强制转换;编译错误
v := interfaceVar.(string)(不带 ok)—— 若类型不符直接 panic,生产环境严禁strconv 返回的 error,比如 i, _ := strconv.Atoi(s) —— 错误被吞掉,逻辑可能出错却无提示实际中常遇到嵌套场景:比如从 JSON 解析出 map[string]interface{},其中某个字段本应是字符串,但想转成整数。这时要分两步:
if s, ok := data["age"].(string); ok { ... }
strconv.Atoi(s) 转数字,并检查 errorif f, ok := data["age"].(float64); ok { age := int(f) },但要注意精度丢失