




Go的fmt包三大输出函数区别在于输出目标和是否格式化:Println简单换行输出、不支持格式化;Printf格式化后输出到控制台;Sprintf格式化后返回字符串。
Go 的 fmt 包提供了三种最常用的输出函数:Println、Printf 和 Sprintf,它们用途不同,关键区别在于“输出到哪里”和“是否格式化”。
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 不会被替换)
✅ 适合调试时快速看值;❌ 不适合构造带格式的字符串。
Printf 接收一个格式化字符串(含 % 开头的动词),再按顺序传入对应类型的参数,最终直接打印到终端,不自动换行。
常用动词:
示例:
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 功能和 Printf 完全一致,但不打印,而是返回一个格式化后的 string,常用于拼接日志、生成文件名、构建 HTTP 请求体等场景。
示例:
title := "Golang fmt"
year := 2025
msg := fmt.Sprintf("Tutorial: %s (%d)", title, year)
fmt.Println(msg) // 输出:Tutorial: Golang fmt (2025)
// 也可直接赋值或传参:
logEntry := fmt.Sprintf("[INFO] %s started at %v", "server", time.Now())
掌握这三者的分工——Println 快速看值、Printf 控制台格式输出、Sprintf 构造字符串——就能清晰选择,写出更稳更可读的 Go 日志和提示逻辑。