golang bad file descriptor問題的解決方法
發(fā)現(xiàn)問題
在golang中,對文件進行寫操作時出現(xiàn)上面的錯誤。首先復現(xiàn)下這個問題。
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) } }
此時運行就會出現(xiàn)錯誤write a.txt: bad file descriptor
。這是什么原因呢?其實這和os.Open()
函數(shù)有關,下面了解下Open()函數(shù)。
func Open(name string) (*File,error) { return OpenFile(name, O_RDONLY, 0) }
可以看出來,Open函數(shù)打開文件的默認方式是只讀,所以當你要對打開的文件進行寫操作時,是不被允許的。OpenFile函數(shù)的第二個傳入?yún)?shù)的值可以是:
參數(shù)名 含義
O_RDONLY 打開只讀文件
O_WRONLY 打開只寫文件
O_RDWR 打開既可以讀取又可以寫入文件
O_APPEND 寫入文件時將數(shù)據(jù)追加到文件尾部
O_CREATE 如果文件不存在,則創(chuàng)建一個新的文件
O_EXCL 文件必須不存在,然后會創(chuàng)建一個新的文件
O_SYNC 打開同步I/0
O_TRUNC 文件打開時可以截斷
解決方法
現(xiàn)在知道原因,解決方法只要改變文件讀取的方式就行。如下例:
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) } }
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關文章
使用golang腳本基于kubeadm創(chuàng)建新的token(問題分析)
這篇文章主要介紹了使用golang腳本基于kubeadm創(chuàng)建新的token(問題分析),本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-10-10Golang對sqlite3數(shù)據(jù)庫進行操作實踐記錄
sqlite是嵌入式關系型數(shù)據(jù)庫引擎,官方描述為自包含的、無服務的、零配置并支持事務的關系型數(shù)據(jù)庫引擎,下面這篇文章主要給大家介紹了關于Golang對sqlite3數(shù)據(jù)庫進行操作的相關資料,需要的朋友可以參考下2024-03-03