登录
首页 >  Golang >  Go问答

Golang 错误的文件描述符

来源:Golang技术栈

时间:2023-04-15 09:51:18 501浏览 收藏

偷偷努力,悄无声息地变强,然后惊艳所有人!哈哈,小伙伴们又来学习啦~今天我将给大家介绍《Golang 错误的文件描述符》,这篇文章主要会讲到golang等等知识点,不知道大家对其都有多少了解,下面我们就一起来看一吧!当然,非常希望大家能多多评论,给出合理的建议,我们一起学习,一起进步!

问题内容

在我的 go 例程中尝试附加到日志文件时,我得到了一个错误的文件描述符。

write ./log.log: bad file descriptor

该文件存在并具有 666 的权限。起初我想可能是因为他们每个人都试图同时打开文件。我实现了一个互斥锁来尝试避免这种情况,但遇到了同样的问题,所以我删除了它。

logCh := make(chan string, 150)
go func() {
    for {
        msg, ok := 

正确答案

您需要添加O_WRONLY标志:

if f, err := os.OpenFile("./log.log", os.O_APPEND|os.O_WRONLY, os.ModeAppend); err != nil { /*[...]*/ }

为了解释,这里是 linux 文档open: http: //man7.org/linux/man- pages/man2/openat.2.html

参数标志必须包括以下访问模式之一:O_RDONLY、O_WRONLY 或 O_RDWR。这些请求分别以只读、只写或读/写方式打开文件。

如果您检查/usr/local/go/src/syscall/zerrors_linux_amd64.go:660,您可以看到:

O_RDONLY                         = 0x0
O_RDWR                           = 0x2
O_WRONLY                         = 0x1

所以默认情况下你会得到一个只读的文件描述符。

好了,本文到此结束,带大家了解了《Golang 错误的文件描述符》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多Golang知识!

声明:本文转载于:Golang技术栈 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>