這篇文章將為大家詳細講解有關如何解決golang bad file descriptor的問題,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
發現問題
在golang中,對文件進行寫操作時出現上面的錯誤。首先復現下這個問題。
package main import ( "os" "fmt" ) func main() { file, err := os.Open("a.txt") if err != nil { fmt.Println(err) } defer file.Close() content:=[]byte("Go is an open source programing language that makes it easy to build simple,reliable,and efficient software") _, err = file.Write(content) if err != nil { fmt.Println(err) } }
此時運行就會出現錯誤write a.txt: bad file descriptor
。這是什么原因呢?其實這和os.Open()
函數有關,下面了解下Open()函數。
func Open(name string) (*File,error) { return OpenFile(name, O_RDONLY, 0) }
可以看出來,Open函數打開文件的默認方式是只讀,所以當你要對打開的文件進行寫操作時,是不被允許的。OpenFile函數的第二個傳入參數的值可以是:
參數名 含義
O_RDONLY 打開只讀文件
O_WRONLY 打開只寫文件
O_RDWR 打開既可以讀取又可以寫入文件
O_APPEND 寫入文件時將數據追加到文件尾部
O_CREATE 如果文件不存在,則創建一個新的文件
O_EXCL 文件必須不存在,然后會創建一個新的文件
O_SYNC 打開同步I/0
O_TRUNC 文件打開時可以截斷
解決方法
現在知道原因,解決方法只要改變文件讀取的方式就行。如下例:
package main import ( "os" "fmt" ) func main() { file, err := os.OpenFile("a.txt", os.O_APPEND|os.O_WRONLY, os.ModeAppend) if err != nil { fmt.Println(err) } defer file.Close() content:=[]byte("Go is an open source programing language that makes it easy to build simple,reliable,and efficient software") _, err = file.Write(content) if err != nil { fmt.Println(err) } }
關于“如何解決golang bad file descriptor的問題”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。