在Go語言中實(shí)現(xiàn)高并發(fā)請求可以通過goroutine和channel來實(shí)現(xiàn)異步操作。下面是一個簡單的示例代碼:
package main
import (
"fmt"
"net/http"
"time"
)
func main() {
start := time.Now()
urls := []string{
"https://www.google.com",
"https://www.facebook.com",
"https://www.youtube.com",
}
// 創(chuàng)建一個無緩沖的channel
ch := make(chan string)
for _, url := range urls {
go fetch(url, ch)
}
for range urls {
fmt.Println(<-ch)
}
fmt.Printf("總共耗時: %.2fs\n", time.Since(start).Seconds())
}
func fetch(url string, ch chan string) {
start := time.Now()
resp, err := http.Get(url)
if err != nil {
ch <- fmt.Sprint(err)
return
}
resp.Body.Close()
elapsed := time.Since(start).Seconds()
ch <- fmt.Sprintf("請求 %s 耗時 %.2fs", url, elapsed)
}
在這個示例中,我們定義了一個包含三個URL的切片,然后使用goroutine并發(fā)地請求這些URL。每個goroutine都會調(diào)用fetch函數(shù)來發(fā)送HTTP請求并計(jì)算耗時,然后將結(jié)果發(fā)送到一個無緩沖的channel中。最后我們通過從channel中讀取結(jié)果來打印每個請求的耗時,并計(jì)算總共的耗時。
通過使用goroutine和channel,我們可以實(shí)現(xiàn)高并發(fā)地發(fā)送HTTP請求并處理響應(yīng),從而提高程序的性能和效率。