Rumah > Artikel > pembangunan bahagian belakang > Mengapa Penambahan Fail Menghasilkan Ralat "Deskriptor Fail Buruk" dalam Go?
Penerangan Fail Buruk Ditemui Semasa Mencuba Penambahan Fail
Apabila cuba menambah fail pengelogan dalam rutin Go, anda mungkin menghadapi ralat "tulis ./log.log: deskriptor fail buruk". Walaupun fail itu wujud dan kebenaran yang sesuai (666), isu ini berterusan.
Pada mulanya, punca itu disyaki akses fail serentak oleh berbilang rutin pergi. Walau bagaimanapun, melaksanakan mutex gagal menyelesaikan isu.
Penyelesaian
Penyelesaian terletak pada penambahan bendera O_WRONLY semasa pembukaan fail:
if f, err := os.OpenFile("./log.log", os.O_APPEND|os.O_WRONLY, os.ModeAppend); err != nil { /*[...]*/ }
Penjelasan
Menurut Linux dokumentasi untuk terbuka, satu daripada tiga mod akses (O_RDONLY, O_WRONLY, atau O_RDWR) mesti dinyatakan. Mod ini meminta membuka fail masing-masing sebagai baca sahaja, tulis sahaja atau baca/tulis.
Secara lalai, deskriptor fail dibuka dalam mod baca sahaja, seperti yang disahkan oleh kod berikut dalam / usr/local/go/src/syscall/zerrors_linux_amd64.go:
O_RDONLY = 0x0 O_RDWR = 0x2 O_WRONLY = 0x1
Oleh itu, secara eksplisit menyatakan O_WRONLY memastikan fail dibuka dalam mod tulis sahaja, menyelesaikan isu awal.
Atas ialah kandungan terperinci Mengapa Penambahan Fail Menghasilkan Ralat "Deskriptor Fail Buruk" dalam Go?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!