通八洲科技

如何使用Go fmt错误格式化输出_Go fmt Error格式输出技巧

日期:2025-12-26 00:00 / 作者:P粉602998670
Go 错误处理应使用 fmt.Errorf(推荐 %w 包装保留错误链)、%v 打印错误、%q 安全插值字符串,并统一用 log 包而非 fmt 输出错误,确保可调试、类型安全且符合 Go 习惯。

Go 的 fmt 包本身不提供“错误格式化输出”的专用函数,但 Go 语言约定使用 error 接口和 fmt.Errorffmt.Sprint/Printf 等组合来清晰、一致地输出错误信息。关键不是“错误格式化”,而是“如何按 Go 习惯正确构造和展示错误”。

用 fmt.Errorf 构建带上下文的错误

推荐用 fmt.Errorf(尤其是带 %w 动词)包装底层错误,保留原始错误链,便于调试和判断类型:

打印错误时优先用 %v 和 %+v

在日志或调试输出中显示错误,应根据需求选择格式动词:

示例:
log.Printf("error occurred: %v", err) —— 清晰、标准、兼容所有 error 类型

避免在错误消息里拼接裸字符串

不要手动用 +fmt.Sprintf 拼接路径、变量等敏感内容,易出错且不安全:

日志中区分错误与普通输出

生产环境别混用 fmt.Printlnlog.Printf 输出错误。统一用结构化日志库(如 log/slog)或至少用 log 包:

基本上就这些。核心是:用 fmt.Errorf 包装、用 %v 打印、用 %q 安全插值、用 log 而非 fmt 做终端输出。不复杂但容易忽略。