Go语言利用goroutine和channel实现异步网络请求,无需第三方库即可编写高效并发代码。通过goroutine发起HTTP请求,主流程不阻塞,适用于日志上报等场景;结合channel可传递结果与错误,支持超时控制,实现结构化回调;使用WaitGroup可并发处理多个请求,提升批量操作效率。配合net/http包,异步编程直观可靠,需注意并发控制、超时设置与资源释放。

Go语言通过原生支持的goroutine和channel机制,轻松实现异步网络请求。不需要引入复杂的第三方库,就能写出高效、可读性强的并发代码。
使用Goroutine发起异步HTTP请求
在Go中,把一个网络请求放到goroutine中执行,就实现了异步调用。主流程不会被阻塞,可以继续处理其他任务。
下面是一个简单的例子:
// 发起异步GET请求
go func() {
resp, err := http.Get(“https://httpbin.org/get”)
if err != nil {
log.Printf(“请求失败: %v”, err)
return
}
defer resp.Body.Close()
body, _ := io.ReadAll(resp.Body)
log.Printf(“响应长度: %d”, len(body))
}()
// 主线程继续执行,不等待请求完成
这种方式适合那些不需要立即获取结果的场景,比如日志上报、事件通知等。
立即学习“go语言免费学习笔记(深入)”;
通过Channel获取异步结果
如果需要在异步请求完成后做进一步处理,可以使用channel传递结果。
type Result struct {
Response []byte
Error error
}
resultCh := make(chan Result, 1)

知网AI智能写作,写文档、写报告如此简单
38
查看详情
go func() {
resp, err := http.Get(“https://www.php.cn/link/c2148796071914983ed6b6e9dbbff735”)
if err != nil {
resultCh <- Result{Error: err}
return
}
defer resp.Body.Close()
body, _ := io.ReadAll(resp.Body)
resultCh <- Result{Response: body}
}()
// 后续可以从 resultCh 接收结果,非阻塞或带超时
select {
case result := <-resultCh:
if result.Error != nil {
log.Printf(“请求出错: %v”, result.Error)
} else {
log.Printf(“收到数据: %s”, result.Response)
}
case <-time.After(5 * time.Second):
log.Println(“请求超时”)
}
这种方式让异步请求具备了结构化错误处理和结果回调的能力。
并发多个异步请求
当需要同时发起多个网络请求时,可以用WaitGroup配合多个goroutine。
urls := []string{
“https://httpbin.org/delay/2”,
“https://httpbin.org/delay/1”,
“https://httpbin.org/get”,
}
var wg sync.WaitGroup
for _, url := range urls {
wg.Add(1)
go func(u string) {
defer wg.Done()
resp, err := http.Get(u)
if err != nil {
log.Printf(“请求 %s 失败: %v”, u, err)
return
}
defer resp.Body.Close()
log.Printf(“完成请求: %s, 状态码: %d”, u, resp.StatusCode)
}(url)
}
wg.Wait() // 等待所有请求完成
这种模式能显著提升批量请求的效率,特别适用于微服务聚合场景。
基本上就这些。Go的net/http包配合并发原语,让异步网络编程变得直观又可靠。关键是要合理控制并发数、设置请求超时、避免资源泄漏。不复杂但容易忽略细节。
大家都在看:
如何利用CSS-in-JS技术动态管理组件的样式与主题?
静态HTML页面JS和CSS加载失败问题及解决方案
为什么推荐用JS而不是直接写HTML_推荐用JS而不是直接写HTML的原因
HTML如何嵌入JS脚本_HTMLscript标签加载JavaScript
































暂无评论内容