ioutil包已废弃,推荐使用io和os新API。ReadFile读取文件为字节切片,适合小文件;WriteFile将数据写入文件并设置权限;TempFile创建临时文件需手动删除。示例涵盖配置读取、内容写入与临时文件处理。go 1.16后应迁移至io.ReadFile和os.WriteFile。

go语言中使用io/ioutil进行文件读写操作已经是一种常见做法,但需要注意的是,从Go 1.16开始,io/ioutil包已被标记为废弃(deprecated)。官方推荐使用io和os包中的函数替代。不过,为了理解旧项目代码或在低版本Go中开发,掌握ioutil的用法仍有实际意义。本文将详解如何使用ioutil读取与写入文件,并提供实用示例。
读取整个文件内容
最常用的ioutil功能是ReadFile,它能一次性读取指定路径的文件内容并返回字节切片。
注意:适用于小文件,大文件可能导致内存占用过高。
使用方法如下:
示例代码:
立即学习“go语言免费学习笔记(深入)”;
content, err := ioutil.ReadFile("config.txt") if err != nil { log.Fatal(err) } fmt.Println(string(content))
将数据写入文件
ioutil提供了WriteFile函数,用于快速将数据写入文件,支持覆盖写入。
该函数参数包括:文件路径、数据字节切片、文件权限模式。
- 数据需为[]byte类型,可通过[]byte(str)转换字符串
- 权限模式常用0644,表示文件所有者可读写,其他用户只读
- 如果文件已存在,原内容会被完全替换
示例:
data := "Hello, golang!" err := ioutil.WriteFile("output.txt", []byte(data), 0644) if err != nil { log.Fatal(err) }
临时文件操作
ioutil.TempFile可用于创建临时文件,适合处理中间数据或缓存内容。
函数接受两个参数:目录路径和文件名模板。
- 传入””表示使用系统默认临时目录(如/tmp)
- 模板名如”tempfile_*.txt”,星号部分会被随机字符替换
- 创建后应记得关闭并删除文件以释放资源
示例:
tmpfile, err := ioutil.TempFile("", "log_*.txt") if err != nil { log.Fatal(err) } defer os.Remove(tmpfile.Name()) // 程序结束前删除 defer tmpfile.Close() msg := []byte("temporary datan") if _, err := tmpfile.Write(msg); err != nil { log.Fatal(err) }
虽然ioutil在旧项目中广泛使用,但从Go 1.16起建议迁移到io.ReadFile和os.WriteFile等新API。这些新函数行为一致且更符合模块化设计。迁移过程不复杂但容易忽略,建议在新项目中直接使用标准库更新后的接口。


