Rumah > Artikel > pembangunan bahagian belakang > Amalan terbaik untuk menggunakan pengaturcaraan serentak Select Channels Go dalam projek golang
Menggunakan Saluran Terpilih Amalan terbaik pengaturcaraan serentak dalam projek golang memerlukan contoh kod khusus
Dengan aplikasi pemproses berbilang teras yang meluas, menulis atur cara serentak telah menjadi bahagian yang sangat penting dalam pembangunan perisian moden. Sebagai bahasa pengaturcaraan serentak yang cekap, bahasa Go menyediakan banyak primitif serentak dan alat untuk memudahkan kerumitan pengaturcaraan serentak.
Antaranya, Pilih dan Saluran ialah salah satu primitif konkurensi yang paling penting dalam bahasa Go. Pilih membolehkan anda memilih antara berbilang saluran dan melakukan operasi yang sepadan berdasarkan input atau output pada saluran. Saluran ialah struktur data yang digunakan untuk komunikasi antara coroutine Go Dengan menggunakan Saluran, coroutine boleh menghantar dan menerima data dengan selamat.
Di bawah ini kami akan memperkenalkan cara menggunakan Select and Channels dalam projek golang tertentu untuk melaksanakan mod konkurensi yang mudah tetapi praktikal. Katakan kami mempunyai program yang perlu memproses berbilang permintaan HTTP Untuk meningkatkan kecekapan, kami berharap permintaan ini boleh diproses secara serentak dan hasilnya akan dikembalikan selepas semua pemprosesan permintaan selesai.
Pertama, kita perlu membuat Saluran untuk menyampaikan respons HTTP, kodnya adalah seperti berikut:
responseChan := make(chan *http.Response) defer close(responseChan)
Seterusnya, kita perlu membuat coroutine untuk mengendalikan setiap permintaan HTTP dan menghantar hasilnya kepada responseChan. Kami boleh mencapai ini melalui fungsi tanpa nama dan kata kunci pergi:
for _, url := range urls { go func(url string) { resp, err := http.Get(url) if err != nil { log.Println(err) return } responseChan <- resp }(url) }
Dalam kod di atas, kami menggunakan gelung for untuk melelaran semua url dan mencipta coroutine baharu melalui fungsi tanpa nama dan pergi kata kunci untuk memproses setiap permintaan. Apabila permintaan selesai, kami menghantar respons HTTP ke responseChan.
Akhir sekali, kami menggunakan penyata pilih untuk menunggu semua pemprosesan permintaan selesai dan mengumpul keputusan. Kodnya adalah seperti berikut:
var responses []*http.Response for i := 0; i < len(urls); i++ { select { case resp := <-responseChan: responses = append(responses, resp) } }
Dalam kod di atas, kami menggunakan penyataan pilih untuk menunggu respons dalam responseChan dan menambahnya pada tatasusunan respons. Apabila semua permintaan diproses, kami boleh mengakses semua respons HTTP melalui tatasusunan respons.
Melalui contoh kod di atas, kami menunjukkan amalan terbaik untuk menggunakan Pilih dan Saluran untuk pengaturcaraan serentak dalam projek golang. Dengan menggunakan Saluran untuk menghantar data dan menggunakan pernyataan Pilih untuk menunggu input atau output berbilang Saluran, kami boleh melaksanakan fungsi memproses berbilang tugas secara serentak dengan mudah.
Dalam projek sebenar, kami boleh mengembangkan dan mengoptimumkan kod di atas mengikut keperluan. Contohnya, anda boleh menggunakan Saluran penimbal untuk meningkatkan daya pemprosesan pemprosesan serentak, atau menggunakan penyataan pilih dengan mekanisme tamat masa untuk mengendalikan situasi tamat masa.
Ringkasnya, Pilih dan Saluran adalah primitif konkurensi yang sangat berkuasa dan ringkas dalam bahasa Go. Dengan menggunakannya dengan sewajarnya, kita boleh mencapai pengaturcaraan serentak yang cekap dan ringkas dalam projek golang.
Atas ialah kandungan terperinci Amalan terbaik untuk menggunakan pengaturcaraan serentak Select Channels Go dalam projek golang. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!