golang ialah bahasa pengaturcaraan yang sangat popular Ia mempunyai banyak ciri unik, salah satu ciri penting ialah ia menyokong pemprosesan selari. Dalam dunia hari ini, permintaan rangkaian telah menjadi sebahagian daripada kehidupan seharian kita. Jika kita perlu meminta berbilang API, bagaimanakah kita boleh menyelesaikan tugasan ini dalam masa yang sesingkat mungkin? Inilah sebenarnya topik permintaan selari golang.
Permintaan selari yang dipanggil hanya bermaksud memulakan berbilang permintaan rangkaian pada masa yang sama untuk meningkatkan kecekapan permintaan. Dalam golang, kita boleh menggunakan goroutine untuk melaksanakan permintaan selari untuk memproses sejumlah besar permintaan dengan cepat.
Pertama, mari kita lihat cara menggunakan goroutine untuk melaksanakan permintaan selari.
package main import ( "fmt" "net/http" ) func main() { urls := []string{ "http://example.com/1", "http://example.com/2", "http://example.com/3", } for _, url := range urls { go func(url string) { res, err := http.Get(url) if err != nil { fmt.Println("Error:", err) return } fmt.Println("Response:", res.Status) }(url) } fmt.Scanln() }
Dalam contoh ini, kami mentakrifkan tatasusunan URL yang mengandungi URL yang perlu kami minta. Kami mengulangi tatasusunan ini dan memulakan goroutine baharu pada setiap URL menggunakan kata kunci go
. Goroutine ini menghantar permintaan HTTP GET dan mengeluarkan respons kepada terminal selepas permintaan selesai.
Permintaan serentak sedemikian akan menjadikan program kami lebih pantas, tetapi pada masa yang sama akan ada beberapa masalah. Pertama, jika kita memulakan terlalu banyak goroutine, kita mungkin melebihi konkurensi maksimum yang dibenarkan oleh sistem pengendalian. Kedua, kita perlu menunggu semua permintaan selesai sebelum kita boleh mendapatkan keputusan, yang mungkin membawa kepada masa tindak balas yang panjang, yang bermaksud kita memerlukan beberapa kaedah pemprosesan yang lebih cekap.
Seterusnya, mari kita lihat cara menggunakan goroutine dan saluran untuk mencapai permintaan selari yang lebih cekap.
package main import ( "fmt" "net/http" ) func main() { urls := []string{ "http://example.com/1", "http://example.com/2", "http://example.com/3", } ch := make(chan string) for _, url := range urls { go func(url string) { res, err := http.Get(url) if err != nil { fmt.Println("Error:", err) return } ch <- fmt.Sprintf("Response from %s: %s", url, res.Status) }(url) } for i := 0; i < len(urls); i++ { fmt.Println(<-ch) } }
Dalam contoh ini, kami mentakrifkan saluran bernama ch
dan kami menghantar hasilnya ke saluran dalam setiap goroutine. Dalam utas utama, kami menggunakan gelung untuk menerima semua hasil dalam saluran dan mencetaknya ke terminal.
Kelebihan menggunakan saluran ialah kita boleh mengawal bilangan goroutin, dan kita tidak perlu menunggu semua goroutin menyelesaikan permintaan sebelum mendapat keputusan. Berbanding dengan menunggu semua permintaan selesai, permintaan selari sedemikian boleh membolehkan kami mendapatkan hasil dengan lebih cepat, dan juga mengelakkan ketinggalan yang disebabkan oleh masa respons yang lama untuk permintaan.
Ringkasnya, permintaan selari golang ialah kaedah yang menggunakan ciri bahasa golang untuk memproses berbilang permintaan rangkaian pada masa yang sama, sekali gus meningkatkan kecekapan permintaan. Dalam melaksanakan permintaan selari, kami boleh menggunakan goroutine dan saluran untuk mengawal keselarasan program dan mengembalikan keputusan serta-merta selepas menerima respons setiap permintaan, membolehkan kami memproses sejumlah besar permintaan dalam masa yang paling singkat.
Atas ialah kandungan terperinci Cara menggunakan goroutine untuk melaksanakan permintaan selari dalam bahasa go. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!