Go中无printf函数,只有需导入"fmt"包的fmt.Printf(输出到标准输出)和fmt.Sprintf(返回格式化字符串),二者均要求格式动词与参数数量类型严格匹配,否则运行时panic。
Go 里没有 printf 函数,只有 fmt.Printf 和 fmt.Sprintf —— 它们不是语法糖,而是标准库函数,必须显式导入 "fmt" 包才能用。
它把格式化后的字符串打印到终端(os.Stdout),不返回值,只返回写入字节数和可能的错误(通常忽略)。
%v、%s、%d、%f 等动词,不支持 Python 风格的 {} 或 f-string
fmt.Printf("name: %s, age: %d", name) —— 少传了 age,会崩溃Printf 和日志库(如 log.Printf),职责要清晰package main import "fmt" func main() { name := "Alice" age := 30 fmt.Printf("Name: %s, Age: %d\n", name, age) // 输出:Name: Alice, Age: 30 }
它不输出,而是把结果作为 string 返回,适合拼接、赋值、传参等场景。这是 Go 中最常用的字符串格式化方式。
Printf 完全一致,只是不打印,所以同样要求格式动词与参数数量/类型匹配Sprintf 会分配内存,高并发或热路径中可考虑 strings.Builder + fmt.Fprint 组合替代Sprintf 拼 SQL 查询(易 SQL 注入),应使用 database/sql 的占位符(? 或 $1)package main
import "fmt"
func main() {
user := "Bob"
score := 95.5
msg := fmt.Sprintf("User %s scored %.1f", user, score)
fmt.Println(msg) // 输出:User Bob scored 95.5
}
Go 对类型检查较严格,%d 传入 float64 或 %s 传入结构体,都会 panic("fmt: %d verb not supported by struct" 类似错误)。
%v 最安全:自动推导,适合调试;但生产环境建议明确动词,提高可读性和类型意图%q 用于带双引号的字符串(如 "hello" → "\"hello\""),常用于日志或生成代码%+v 打印结构体字段名({Name:"Tom", Age:28}),%#v 输出 Go 语法风格(main.User{Name:"Tom", Age:28})int64 却用 %d 没问题(兼容),但传 uint64 用 %d 会报错,得用 %d 配 int、%v 或 %#v,或显式转成 int64 后用 %d
fmt.Printf 和 fmt.Fprintf(写入 io.Writer)都返回 (n int, err error),虽然终端输出极少出错,但写文件或网络连接时可能失败。
n, err := fmt.Fprintf(file, "log: %v", data) —— 必须检查 err,否则写入失败会被静默忽略Sprintf 不会返回 error(只要参数合法),但若格式字符串本身非法(如 "%z" 这种未定义动词),会在运行时 panic,不是编译期错误go vet,它能捕获部分格式动词与参数不匹配的问题(比如 %s 后跟 int)真正容易被忽略的是:格式字符串里的空格、换行、标点都是字面量,不会自动补全或裁剪 —— 写 "%s:%d" 就真没空格,写成 "%s: %d" 才有。这种细节在日志对齐、API 响应拼接时直接影响可读性。