Mengendalikan Panik dalam Goroutines untuk Memastikan Pelaksanaan Berterusan
Dalam Go, goroutine menyediakan mekanisme konkurensi yang ringan. Walau bagaimanapun, apabila satu goroutine ranap atau panik, tingkah laku lalai adalah untuk keseluruhan program keluar. Ini boleh menjadi masalah jika anda ingin mengekalkan pelaksanaan goroutine lain yang tidak berkaitan dengan goroutine yang ranap.
Untuk menangani isu ini, kami boleh memanfaatkan fungsi recover() terbina dalam bersama-sama dengan fungsi tertunda. Fungsi recover() membolehkan kami pulih daripada panik dan mendapatkan semula kawalan program dalam goroutine tempat panik berlaku. Begini cara kita boleh mencapainya:
Berikut ialah versi terkini coretan kod anda yang menggabungkan mekanisme pemulihan:
func main() { // Create a separate goroutine for recovery go func() { defer func() { if err := recover(); err != nil { log.Printf("Recovered: %v", err) } }() // Wrap the potentially panicking functions in deferred function go func() { defer recover() queue.ConsumeAndDoSomething() }() go func() { defer recover() api.StartServer() }() }() // Block indefinitely to keep the program running <-make(chan struct{}) }
Dengan melaksanakan mekanisme pemulihan ini, kami memastikan pelaksanaan goroutine lain tidak terjejas jika salah seorang goroutine panik. Program ini akan terus berjalan dan mengendalikan panik dengan anggun, menyediakan persekitaran pelaksanaan yang lebih berdaya tahan.
Atas ialah kandungan terperinci Bagaimana Saya Boleh Menghalang Panik Goroutine Tunggal daripada Menghancurkan Seluruh Program Go Saya?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!