日常调试用log.Println,结构化日志必须用log.Printf;需时间戳和行号则设log.SetFlags(log.LstdFlags | log.Lshortfile);写文件要用os.OpenFile并检查err;分级和上下文需换zap/slog。log.Println 和 log.Printf 到底该用哪个直接结论:日常调试用 log.Println,结构化/可读性要求高的日志必须用 log.Printf。log.Println 会自动在参数间加空格、末尾加换行,适合快速打点;但一旦涉及变量拼接(比如 log.Println("user:", user)),结构体或 map 会输出内存地址,不是你想要的字段值。log.Printf 支持格式化,能精准控制输出内容和对齐,且不自动换行------漏写 会导致多条日志挤在同一行,这是线上排查时最常被忽略的细节之一。想打印用户 ID 和名字?用 log.Printf("user id=%d name=%s", u.ID, u.Name),别用 log.Println("user id=", u.ID, "name=", u.Name)错误日志建议统一用 %v: log.Printf("failed to parse config: %v", err),避免手动调 err.Error()如果只是临时看一眼,log.Println 省事;但只要日志要留存、要搜索、要进 ELK,一律上 log.Printf如何让每条日志带时间戳和文件行号标准库默认不带这些信息,必须显式启用------靠 log.SetFlags,不是靠"猜"或"重装包"。立即学习"go语言免费学习笔记(深入)";log.LstdFlags 包含日期 + 时间(精确到秒),log.Lshortfile 输出 main.go:42 这种紧凑格式。两者组合最常用,也最实用。 AI Code Reviewer AI自动审核代码
相关推荐
金銀銅鐵7 分钟前
用 Python 实现 Take-Away 游戏copyer_xyf1 小时前
Agent 流程编排copyer_xyf1 小时前
Agent RAGcopyer_xyf1 小时前
【RAG】向量数据库:milvuscopyer_xyf2 小时前
Agent 记忆管理星云穿梭17 小时前
用Python写一个带图形界面的学生管理系统——完整教程金銀銅鐵17 小时前
用 Pygame 实现 15 puzzle倔强的石头_1 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战黄忠1 天前
大模型之LangGraph技术体系冬奇Lab1 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite