临时文件和目录
在程序运行时,我们经常创建一些运行时用到,程序结束后就不再使用的数据。 临时目录和文件 对于上面的情况很有用,因为它不会随着时间的推移而污染文件系统。
代码示例
package main
import (
"fmt"
"os"
"path/filepath"
)
func check(e error) {
if e != nil {
panic(e)
}
}
func main() {
// 创建临时文件最简单的方法是调用 os.CreateTemp 函数。 它会创建并打开文件,我们可以对文件进行读写。 函数的第一个参数传 "",os.CreateTemp 会在操作系统的默认位置下创建该文件。
f, err := os.CreateTemp("", "sample")
check(err)
// 打印临时文件的名称。 文件名以 os.CreateTemp 函数的第二个参数作为前缀, 剩余的部分会自动生成,以确保并发调用时,生成不重复的文件名。 在类 Unix 操作系统下,临时目录一般是 /tmp。
fmt.Println("Temp file name:", f.Name())
// defer 删除该文件。 尽管操作系统会自动在某个时间清理临时文件,但手动清理是一个好习惯。
defer os.Remove(f.Name())
// 我们可以向文件写入一些数据。
_, err = f.Write([]byte{1, 2, 3, 4})
check(err)
// 如果需要写入多个临时文件,最好是为其创建一个临时 目录 。 os.MkdirTemp 的参数与 CreateTemp 相同, 但是它返回的是一个 目录名 ,而不是一个打开的文件。
dname, err := os.MkdirTemp("", "sampledir")
fmt.Println("Temp dir name:", dname)
defer os.RemoveAll(dname)
// 现在,我们可以通过拼接临时目录和临时文件合成完整的临时文件路径,并写入数据。
fname := filepath.Join(dname, "file1")
err = os.WriteFile(fname, []byte{1, 2}, 0666)
check(err)
}