0

0

Go语言如何使用临时文件_ioutil TempFile使用说明

P粉602998670

P粉602998670

发布时间:2026-01-17 14:24:09

|

235人浏览过

|

来源于php中文网

原创

Go 1.16+ 必须用 os.CreateTemp 替代已弃用并移除的 ioutil.TempFile;其参数为 dir 和 pattern(需含 ""),返回已打开且权限 0600 的文件,常见错误包括漏写 ""、重复打开及路径构造不当。

go语言如何使用临时文件_ioutil tempfile使用说明

ioutil.TempFile 在 Go 1.16+ 已被弃用,直接使用 os.CreateTemp —— 这是当前唯一推荐方式,旧代码升级时必须改。

为什么不能继续用 ioutil.TempFile

Go 1.16 开始,ioutil 包整体被移入 ioos,其中 ioutil.TempFile 的功能完全由 os.CreateTemp 承接。继续保留旧导入会触发编译错误undefined: ioutil.TempFile

  • Go 1.15 及更早:可用,但已标记为 deprecated
  • Go 1.16+:ioutil 包不存在,必须切换
  • 行为上二者几乎一致,但 os.CreateTemp 参数顺序更合理(先 dir 后 pattern)

os.CreateTemp 基本用法与参数含义

签名是 func CreateTemp(dir, pattern string) (f *os.File, err error),关键点在于:

  • dir:临时目录路径,传空字符串 "" 表示使用系统默认(os.TempDir()
  • pattern:文件名模板,必须包含至少一个 "*",会被替换成随机字符串(如 "myapp-*.log"
  • 返回的 *os.File 已打开(可读写),且权限默认为 0600(仅当前用户可读写)
tmpFile, err := os.CreateTemp("", "backup-*.json")
if err != nil {
    log.Fatal(err)
}
defer os.Remove(tmpFile.Name()) // 记得清理
defer tmpFile.Close()

_, _ = tmpFile.WriteString(`{"data":"example"}`)

常见错误和兼容性注意点

实际写代码时容易卡在这几个地方:

立即学习go语言免费学习笔记(深入)”;

网奇英文商城外贸系统
网奇英文商城外贸系统

网奇Eshop是一个带有国际化语言支持的系统,可以同时在一个页面上显示全球任何一种语言而没有任何障碍、任何乱码。在本系统中您可以发现,后台可以用任意一种语言对前台进行管理、录入而没有阻碍。而任何一个国家的浏览者也可以用他们的本国语言在你的网站上下订单、留言。用户可以通过后台随意设定软件语言,也就是说你可以用本软件开设简体中文、繁体中文与英文或者其他语言的网上商店。网奇Eshop系统全部版本都使用模

下载
  • 传错 pattern:漏掉 "*"(如 "backup.json")→ 报错 "pattern contains no asterisk"
  • 忽略返回的 *os.File 已打开 → 重复 os.Open 导致 “text file busy” 或权限错误
  • 在 Windows 上指定 dir 时路径末尾带反斜杠但没转义 → 字符串解析失败(建议用 filepath.Join 构造路径)
  • 并发调用未加锁 → 虽然 os.CreateTemp 内部是线程安全的,但若多个 goroutine 共享同一 dir 且磁盘空间紧张,可能因竞争创建失败

替代方案:需要自定义权限或不立即打开文件时

如果明确不想一创建就打开文件,或需要非 0600 权限(比如让其他进程可读),就不能用 os.CreateTemp,而应组合使用 os.MkdirTemp + os.OpenFile

dir, err := os.MkdirTemp("", "myapp-*")
if err != nil {
    log.Fatal(err)
}
defer os.RemoveAll(dir)

filePath := filepath.Join(dir, "config.yaml")
f, err := os.OpenFile(filePath, os.O_CREATE|os.O_WRONLY, 0644)
if err != nil {
    log.Fatal(err)
}
defer f.Close()

这种写法更灵活,但多了两步操作,日常临时文件场景优先选 os.CreateTemp

真正容易被忽略的是:临时文件名里的随机段长度固定为 10 字符,且不含路径分隔符——所以别试图在 pattern 里写 "subdir/*.log",它只会创建在根临时目录下,"*" 不负责路径生成。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

412

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

533

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

309

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

317

2023.08.02

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

187

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

280

2023.10.25

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

257

2023.08.03

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

27

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 8.3万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号