Go的fmt包三大输出函数区别在于输出目标和是否格式化:Println简单换行输出、不支持格式化;Printf格式化后输出到控制台;Sprintf格式化后返回字符串。

Go 的 fmt 包提供了三种最常用的输出函数:Println、Printf 和 Sprintf,它们用途不同,关键区别在于“输出到哪里”和“是否格式化”。
Println:简单换行输出,不支持格式化占位符
Println 用于快速打印变量值,自动在末尾加换行,并在多个参数间加空格。它不识别 %v、%s 等格式动词,传入格式字符串也不会被解析。
示例:
fmt.Println("Hello", 42, true) // 输出:Hello 42 true
fmt.Println("Name: %s, Age: %d", "Alice", 30) // 输出:Name: %s, Age: %d Alice 30(%s 不会被替换)
✅ 适合调试时快速看值;❌ 不适合构造带格式的字符串。
立即学习“go语言免费学习笔记(深入)”;
Printf:格式化并直接输出到标准输出(控制台)
Printf 接收一个格式化字符串(含 % 开头的动词),再按顺序传入对应类型的参数,最终直接打印到终端,不自动换行。
常用动词:
- %v:默认格式(自动推断类型,如 struct 显示字段,slice 显示元素)
- %s:字符串
- %d:十进制整数
- %f:浮点数(默认小数点后6位)
- %t:布尔值
- %q:带双引号的字符串(转义特殊字符)
示例:
name := "Bob"
age := 28
fmt.Printf("Name: %s, Age: %d\n", name, age) // 输出:Name: Bob, Age: 28
fmt.Printf("Value: %v\n", []int{1, 2, 3}) // 输出:Value: [1 2 3]
fmt.Printf("Quoted: %q\n", "hello\nworld") // 输出:Quoted: "hello\nworld"
Sprintf:格式化并返回字符串,不输出到屏幕
Sprintf 功能和 Printf 完全一致,但不打印,而是返回一个格式化后的 string,常用于拼接日志、生成文件名、构建 HTTP 请求体等场景。
示例:
title := "Golang fmt"
year := 2024
msg := fmt.Sprintf("Tutorial: %s (%d)", title, year)
fmt.Println(msg) // 输出:Tutorial: Golang fmt (2024)
// 也可直接赋值或传参:
logEntry := fmt.Sprintf("[INFO] %s started at %v", "server", time.Now())
小贴士:避免常见错误
- 传参个数必须与格式动词数量严格匹配,否则 panic(运行时报错)
- 类型要匹配:%d 只接受整数,传 float64 会报错;可用 %v 更安全
- 忘记 \n:Printf 不换行,连续调用会挤在同一行,记得手动加 \n
- Sprintf 返回 string,别误写成 fmt.Printf(...).String()(Sprintf 没有 String 方法)
掌握这三者的分工——Println 快速看值、Printf 控制台格式输出、Sprintf 构造字符串——就能清晰选择,写出更稳更可读的 Go 日志和提示逻辑。










