Temporary Files and Directories->临时文件和目录
#
// 在程序运行时,我们经常创建一些运行时用到,程序结束后就不再使用的数据。
// *临时目录和文件* 对于上面的情况很有用,因为它不会随着时间的推移而污染文件系统。
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)
}
$ go run temporary-files-and-directories.go
Temp file name: /tmp/sample610887201
Temp dir name: /tmp/sampledir898854668