ioutil包曾用于简化文件操作,如ReadFile读取、WriteFile写入和TempFile创建临时文件,适合处理配置、日志等场景;尽管Go 1.16后推荐使用os包中功能一致的新函数以提升维护性,但理解其用法仍有助于维护旧代码。

Go语言中,io/ioutil 包曾是简化文件读写操作的重要工具。虽然在Go 1.16之后已被标记为废弃,推荐使用 io 和 os 包中的函数替代,但理解其用法仍有助于维护旧代码,并快速掌握Go中文件操作的核心思想。
读取整个文件内容
使用 ioutil.ReadFile 可以一行代码读取文件全部内容,返回字节切片和错误。
例如:
- 直接读取配置文件或小体积文本,无需手动打开关闭文件。
- 适合处理日志、JSON配置等场景。
代码示例:
立即学习“go语言免费学习笔记(深入)”;
content, err := ioutil.ReadFile("config.json")
if err != nil {
log.Fatal(err)
}
fmt.Println(string(content))
将字符串写入文件
ioutil.WriteFile 支持将数据写入文件,自动创建或覆盖目标文件。
常用场景包括:
- 生成临时文件或导出数据。
- 保存程序运行结果,如日志、序列化数据。
示例:
data := "Hello, Golang!"
err := ioutil.WriteFile("output.txt", []byte(data), 0644)
if err != nil {
log.Fatal(err)
}
第三个参数是文件权限,一般设为 0644,表示所有者可读写,其他用户只读。
临时文件的快速创建与使用
ioutil.TempFile 能在指定目录下创建唯一的临时文件,常用于缓存、中间数据存储。
特点:
- 文件名唯一,避免冲突。
- 建议使用后立即删除,防止磁盘占用。
示例:
tmpfile, err := ioutil.TempFile("", "tmp-example-*.txt")
if err != nil {
log.Fatal(err)
}
defer os.Remove(tmpfile.Name()) // 使用后清理
defer tmpfile.Close()
content := []byte("临时数据")
tmpfile.Write(content)
基本上就这些。尽管 ioutil 已被弃用,但它的设计思路清晰体现了Go对简洁API的追求。现在推荐改用 os.ReadDir、os.ReadFile 和 os.WriteFile 等新函数,用法几乎一致,更统一且维护性更好。过渡不复杂,但容易忽略。










