从Go 1.16起应使用os.WriteFile替代ioutil.WriteFile写入文件,两者用法相似,需将字符串转为字节切片并设置文件权限如0644,确保UTF-8编码。

在 Go 语言中,io/ioutil 包曾被广泛用于文件操作,包括写入文件。但需要注意的是,从 Go 1.16 开始,ioutil 包已被废弃,其功能合并到了 io 和 os 包中。尽管如此,了解如何使用 ioutil.WriteFile 仍有助于理解旧项目中的代码逻辑。
使用 ioutil.WriteFile 写入字符串到文件
ioutil.WriteFile 是一个便捷函数,可以将字节切片一次性写入文件。如果要写入字符串,需先将其转换为字节切片。
示例代码:
package main
import (
"io/ioutil"
"log"
)
func main() {
content := "Hello, Golang!\n这是写入文件的示例。"
err := ioutil.WriteFile("example.txt", []byte(content), 0644)
if err != nil {
log.Fatalf("写入文件失败: %v", err)
}
}
设置正确的文件权限
第三个参数是文件的权限模式(mode),通常设为 0644,表示文件所有者可读写,其他用户只读。在 Unix/Linux 系统中,权限影响文件安全性。
立即学习“go语言免费学习笔记(深入)”;
常见权限说明:
-
0644: 所有者可读写,组和其他用户只读 -
0600: 仅所有者可读写(更安全) -
0755: 所有者可读写执行,其他用户可读和执行(适用于可执行文件)
替代方案:使用 os.WriteFile(Go 1.16+)
由于 ioutil.WriteFile 已被弃用,推荐使用 os.WriteFile,它位于标准库的 os 包中,用法几乎一致。
更新后的写法:
package main
import (
"os"
"log"
)
func main() {
content := "使用 os.WriteFile 写入文件"
err := os.WriteFile("example.txt", []byte(content), 0644)
if err != nil {
log.Fatalf("写入失败: %v", err)
}
}
基本上就这些。虽然 ioutil.WriteFile 使用简单,但在新项目中应优先使用 os.WriteFile,以保持与现代 Go 版本的兼容性和维护性。不复杂但容易忽略的是权限设置和字符编码(确保内容是 UTF-8)。










