使用os.CreateTemp创建临时文件,通过dir指定目录、pattern定义命名模板,写入读取时需重置文件指针,务必用defer os.Remove确保删除,避免磁盘泄漏。

在Go语言中,操作临时文件是很多程序的常见需求,比如缓存数据、文件上传中转、测试用例等。标准库 io/ioutil(在Go 1.16后部分迁移到 os 包)提供了 TempFile 函数来方便地创建和使用临时文件。下面介绍它的正确使用方式和一些实用技巧。
创建临时文件:使用 os.CreateTemp
从 Go 1.16 开始,ioutil.TempFile 被标记为废弃,推荐使用 os.CreateTemp 替代。它用法更清晰,功能一致。
函数签名如下:
func CreateTemp(dir, pattern string) (*os.File, error)参数说明:
立即学习“go语言免费学习笔记(深入)”;
- dir:指定临时文件创建的目录。传入空字符串表示使用系统默认目录(如 /tmp)。
- pattern:文件名模板,末尾可带“*”,系统会自动替换为随机字符,避免冲突。
示例代码:
file, err := os.CreateTemp("", "example-*.txt") if err != nil { log.Fatal(err) } defer os.Remove(file.Name()) // 确保使用后删除 defer file.Close() fmt.Println("临时文件路径:", file.Name())写入与读取临时文件
创建后,临时文件就是一个普通的 *os.File,可以像操作普通文件一样读写。
示例:写入内容并读回
content := []byte("Hello, Temp File!\n") if _, err := file.Write(content); err != nil { log.Fatal(err) } // 重置读取位置 file.Seek(0, 0) data, _ := io.ReadAll(file) fmt.Printf("读取内容:%s", data)注意:写完后如果要读取,需调用 Seek(0, 0) 将文件指针移回开头。
指定目录与命名技巧
你可以控制临时文件的存放位置:
- 使用 os.TempDir() 获取系统临时目录路径。
- 将 dir 设为某个子目录(需确保存在),便于管理或隔离。
- pattern 中的“*”会被随机字符串替换,建议保留以增强安全性。
例如:
dir := os.TempDir() file, _ := os.CreateTemp(dir, "myapp-*.tmp")自动清理很重要
临时文件不会自动删除,必须手动处理,否则会造成磁盘泄漏。
最佳实践:
- 使用 defer os.Remove(file.Name()) 在函数退出时删除。
- 即使程序崩溃也要尽量清理,可结合 defer 使用。
- 在测试中尤其要注意,多个测试用例可能生成大量临时文件。
完整示例:
file, err := os.CreateTemp("", "demo-*.tmp") if err != nil { log.Fatal(err) } defer os.Remove(file.Name()) defer file.Close() file.WriteString("临时数据")基本上就这些。os.CreateTemp 简单安全,配合 defer 清理,就能高效可靠地使用临时文件。关键是记得删除,别让临时变永久。










