ioutil是Go中封装io和os的工具包,提供ReadFile、WriteFile、TempFile等简易文件操作方法,适用于小文件快速处理,但Go 1.16起推荐改用os包。

在Go语言中,ioutil 是 io 和 os 包的封装,提供了简单的文件读写方法,适合快速处理小文件。虽然从 Go 1.16 开始官方建议使用 os 包替代 ioutil,但在旧项目中仍常见。以下是常用方法及示例。
读取整个文件内容
ioutil.ReadFile 可以一次性读取文件全部内容,返回字节切片和错误。
- 无需手动打开或关闭文件,自动管理资源
- 适用于配置文件、小文本等场景
- 大文件慎用,可能占用过多内存
示例代码:
content, err := ioutil.ReadFile("example.txt")
if err != nil {
log.Fatal(err)
}
fmt.Println(string(content))
将字符串写入文件
ioutil.WriteFile 支持将数据写入文件,若文件已存在则覆盖,可设置文件权限。
立即学习“go语言免费学习笔记(深入)”;
- 第二个参数需为字节切片,可用 []byte() 转换字符串
- 第三个参数是文件权限,如 0644 表示所有者可读写,其他用户只读
- 路径不存在时会报错,需确保目录已创建
示例代码:
data := "Hello, Golang!"
err := ioutil.WriteFile("output.txt", []byte(data), 0644)
if err != nil {
log.Fatal(err)
}
临时文件操作
ioutil.TempFile 用于创建临时文件,常用于缓存或中间数据存储。
- 第一个参数是目录路径,传 "" 使用系统默认临时目录
- 第二个参数是文件名模板,后缀带 * 号会被随机字符替换
- 使用完应调用 Close 和 os.Remove 清理
示例代码:
tmpfile, err := ioutil.TempFile("", "temp-*.txt")
if err != nil {
log.Fatal(err)
}
defer os.Remove(tmpfile.Name()) // 清理
defer tmpfile.Close()
content := []byte("temporary data")
tmpfile.Write(content)
基本上就这些。ioutil 方法简单直接,适合脚本或小型程序。对于生产环境或大文件处理,推荐改用 os.Open、bufio 等更可控的方式。不复杂但容易忽略的是资源清理和权限设置。










