最安全高效的方式是使用 os.Truncate 或 *os.File.Truncate(0) 截断文件至0字节,避免读写、节省资源、保留元信息;切勿用 WriteFile 等写空切片方式清空大文件。
用 Golang 清空大文件内容,最安全高效的方式不是读取再写空,而是直接截断(truncate)文件。这能避免内存占用、I/O 延迟,且对任意大小的文件都几乎瞬时完成。
这是标准库提供的原生方法,底层调用系统 truncate 系统调用,不涉及数据读写,速度快、资源省。
示例代码:
err := os.Truncate("large.log", 0)
if err != nil {
log.Fatal("清空失败:", err)
}
适用于需要复用文件句柄、或在打开时就决定是否清空的场景(比如日志轮转前重置)。
示例:
f, err := os.OpenFile("data.bin", os.O_RDWR, 0644)
if err != nil {
log.Fatal(err)
}
defer f.Close()
if err = f.Truncate(0); err != nil {
log.Fatal("截断失败:", err)
}
这些函数会把整个空字节切片(如 []byte{})写入,看似简洁,但在某些系统或 Go 版本中可能触发缓冲区分配或同步行为,对 GB 级文件反而引入不必要的开销和风险。
os.Truncate 和 f.Truncate 默认保持文件的 mode、uid/gid 不变,无需额外操作。但如果你是先删除再创建同名文件,则会丢失原始权限和属主 —— 这正是为什么 truncate 是首选。
基本上就这些。截断是清空大文件的底层共识,Golang 封装得足够干净,直接用 os.Truncate(路径, 0) 就行,不复杂但容易忽略。