os.Remove用于删除文件或空目录,删除非空目录会报错;os.RemoveAll可递归删除整个目录树,即使路径不存在也不报错,适用于清理操作,需注意权限和误删风险。
在Go语言中,删除文件和目录主要依赖标准库 os 包中的 Remove 和 RemoveAll 函数。虽然函数名相似,但使用场景和行为有明显区别。正确选择方法能避免程序出错,尤其是处理非空目录时。
os.Remove:删除单个文件或空目录
os.Remove 可用于删除一个文件或一个空目录。如果尝试删除非空目录,会返回错误。
示例:删除一个普通文件
err := os.Remove("example.txt")
if err != nil {
log.Fatal(err)
}
这段代码会删除当前目录下的 example.txt。若文件不存在或无权限,err 将非空。
你也可以用它删除一个空目录:
err := os.Remove("empty_dir")
if err != nil {
log.Fatal(err)
}
前提是 empty_dir 目录必须为空,否则操作失败。
os.RemoveAll:强制删除目录及其内容
当需要删除包含文件或子目录的整个目录结构时,应使用 os.RemoveAll。它会递归删除目录下所有内容,无论是否为空。
示例:删除非空目录
err := os.RemoveAll("my_folder")
if err != nil {
log.Fatal(err)
}
这会彻底删除 my_folder 及其内部所有文件和子目录。适用于临时目录清理、项目构建清理等场景。
注意:RemoveAll 即使路径不存在也不会报错,行为类似于 Unix 的 rm -rf。
常见问题与注意事项
- 权限不足时,两个函数都会返回 permission denied 错误,需确保程序有足够权限。
- 删除前可先用 os.Stat 检查文件或目录是否存在,但这不是必须的,因为删除操作本身是幂等的。
- Windows 系统下,正在被使用的文件无法删除,会返回错误。
- 慎用 RemoveAll,避免误删重要数据,建议在关键路径上加确认逻辑。
基本上就这些。根据目标是文件、空目录还是整棵目录树,选择 os.Remove 或 os.RemoveAll 即可。不复杂但容易忽略细节。








