Isu Deskriptor Fail di Golang: "Deskriptor Fail Buruk" Selesai
Apabila cuba menambah fail pengelogan dalam rutin Go, pembangun mungkin menghadapi ralat "deskriptor fail buruk". Isu ini boleh menjadi sangat membingungkan apabila fail itu wujud dan mempunyai kebenaran yang sesuai.
Pada mulanya, nampaknya berbilang rutin yang cuba membuka fail secara serentak boleh menyebabkan masalah. Walau bagaimanapun, walaupun selepas melaksanakan mutex untuk menghalang perkara ini, ralat yang sama berterusan.
Penyelesaian terletak pada menambahkan bendera O_WRONLY pada pernyataan pembukaan fail. Secara lalai, operasi terbuka membuka fail dalam mod baca sahaja. Tanpa menyatakan bendera tulis sahaja secara eksplisit, sebarang percubaan untuk menulis pada fail akan gagal dengan ralat "deskriptor fail buruk".
Berikut ialah versi ubah suai coretan kod yang termasuk bendera O_WRONLY:
if f, err := os.OpenFile("./log.log", os.O_APPEND|os.O_WRONLY, os.ModeAppend); err != nil { panic(err) }
Dengan pengubahsuaian ini, fail akan dibuka dengan kebenaran tambah dan tulis sahaja, menyelesaikan masalah "buruk fail deskriptor" ralat dan membenarkan penulisan yang berjaya pada fail pengelogan.
Atas ialah kandungan terperinci Mengapa Saya Mendapat Ralat 'Deskriptor Fail Buruk' Semasa Melampirkan pada Fail Go Log?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!