Rumah >pembangunan bahagian belakang >Golang >Mengapa Penambahan Fail Menghasilkan Ralat 'Deskriptor Fail Buruk' dalam Go?

Mengapa Penambahan Fail Menghasilkan Ralat 'Deskriptor Fail Buruk' dalam Go?

Susan Sarandon
Susan Sarandonasal
2024-11-11 15:56:03801semak imbas

Why Does Appending to a File Result in a

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!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn