从go 1.16起,ioutil.ReadFile/WriteFile被os.ReadFile/WriteFile替代,临时文件和目录创建分别使用os.CreateTemp和os.MkdirTemp,需注意权限设置与defer清理资源。
go语言中,io/ioutil 包曾被广泛用于文件的读写和临时文件操作。但从 Go 1.16 开始,该包已被弃用,其功能整合到了 io 和 os 包中。现在推荐使用 os 和 io 提供的新函数来完成相关操作。
读取整个文件内容
以前使用
ioutil.ReadFile
可以一次性读取文件全部内容。现在应使用
os.ReadFile
:
这个函数适合小文件,会将整个文件加载到内存。
写入文件内容
过去用
ioutil.WriteFile
写入数据,现在使用
os.WriteFile
:
立即学习“go语言免费学习笔记(深入)”;
- content := []byte(“Hello, golang!”)
- err := os.WriteFile(“output.txt”, content, 0644)
- if err != nil {
- log.Fatal(err)
- }
第三个参数是文件权限,通常设为 0644,表示所有者可读写,其他用户只读。
创建和使用临时文件
虽然
ioutil.TempFile
被弃用,但
os.CreateTemp
提供了相同功能:
- f, err := os.CreateTemp(“”, “tempfile-*.txt”)
- if err != nil {
- log.Fatal(err)
- }
- defer os.Remove(f.Name()) // 使用后清理
- defer f.Close()
- _, err = f.Write([]byte(“临时数据”))
- if err != nil {
- log.Fatal(err)
- }
第一个参数为空字符串时,系统自动选择临时目录(如 /tmp)。通配符 * 会被随机字符替换,确保文件名唯一。
创建临时目录
需要临时存放多个文件时,可用
os.MkdirTemp
:
- dir, err := os.MkdirTemp(“”, “tempdir-*”)
- if err != nil {
- log.Fatal(err)
- }
- defer os.RemoveAll(dir) // 整个目录删除
- filePath := filepath.Join(dir, “config.json”)
- os.WriteFile(filePath, []byte(`{“key”:”value”}`), 0644)
这种方式适合测试或中间处理场景,避免污染正式文件系统。
基本上就这些。Go 的新 API 更清晰地把功能归类到 os 和 io 包中,迁移旧代码只需替换函数名并引入正确的包。不复杂但容易忽略的是权限设置和资源释放,记得用 defer 清理临时文件或目录。
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END
暂无评论内容