Rumah >pembangunan bahagian belakang >Golang >Bagaimanakah Kami Boleh Multiplex Multiple Go Channels dengan Betul untuk Mengelakkan Keadaan Perlumbaan dan Kehilangan Data?
Saluran Berganda
Artikel ini membincangkan fungsi pemultipleks yang bertujuan untuk menggabungkan output tatasusunan saluran ke dalam satu saluran. Walau bagaimanapun, pelaksanaan yang disediakan mempamerkan beberapa isu yang menghalang kefungsiannya.
Kod asal:
func Mux(channels []chan big.Int) chan big.Int { // Count down as each channel closes. When hits zero - close ch. n := len(channels) // The channel to output to. ch := make(chan big.Int, n) // Make one go per channel. for _, c := range channels { go func() { // Pump it. for x := range c { ch <- x } // It closed. n -= 1 // Close output if all closed now. if n == 0 { close(ch) } }() } return ch }
Ralat dalam Pelaksanaan:
Penutupan daripada Pelbagai Goroutine: Pembolehubah n dikongsi antara berbilang goroutine dan dikemas kini oleh setiap goroutine apabila ia mengesan penutupan saluran. Ini boleh mengakibatkan keadaan perlumbaan dan tingkah laku yang tidak dijangka apabila berbilang gorout cuba mengakses dan mengemas kini secara serentak.
Tangkapan Saluran Tidak Betul: Gorut yang dibuat dalam gelung setiap satu menangkap saluran yang sama (yang terakhir elemen saluran) kerana c diberikan nilai saluran pada setiap lelaran, dan bukannya dihantar ke goroutine fungsi.
Isu Selesai:
Untuk menangani masalah ini, kod yang diubah suai menggunakan teknik yang lebih selamat:
Menggunakan WaitGroup: Penyegerakan.WaitGroup digunakan untuk menjejaki penyiapan goroutin. Setiap goroutine memberi isyarat kepada WaitGroup apabila ia telah selesai mengepam data, dan goroutine utama menunggu semua goroutine selesai sebelum menutup saluran keluaran.
Tangkapan Saluran Betul: Setiap goroutine diluluskan saluran. ia harus mendengar dalam fungsi lambda, memastikan setiap goroutine memantau dengan betul saluran.
Output Yang Dipertingkat: Kod yang diubah suai menghasilkan output yang dijangkakan, di mana semua saluran menyumbang kepada saluran output dalam pengagihan yang sekata. Suapan berurutan yang diperhatikan dalam output asal dihapuskan.
Pertimbangan Tambahan:
Atas ialah kandungan terperinci Bagaimanakah Kami Boleh Multiplex Multiple Go Channels dengan Betul untuk Mengelakkan Keadaan Perlumbaan dan Kehilangan Data?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!