context是Go中控制协程生命周期和传递请求数据的核心机制,通过Done通道传递取消信号。2. 使用WithCancel、WithTimeout、WithDeadline创建可取消的上下文,需调用cancel避免泄漏。3. WithValue可附加请求范围的数据,所有派生context共享取消通知。

在Go语言中,context 是控制协程生命周期、传递请求范围数据以及处理取消信号的核心机制。它广泛应用于HTTP服务、数据库调用、超时控制等场景。理解 context 的语法和正确使用取消信号,是编写健壮并发程序的关键。
context 包的核心是 Context 接口,包含四个方法:Deadline、Done、Err 和 Value。其中 Done 方法返回一个只读的 chan,用于监听取消信号。
创建 context 通常从两个根节点开始:
基于根 context,可以派生出带功能的子 context:
立即学习“go语言免费学习笔记(深入)”;
取消信号通过 channel 通知所有下游协程。一旦 context 被取消,其 Done channel 就会被关闭,监听该 channel 的 select 语句会立即触发。
常见模式如下:
ctx, cancel := context.WithTimeout(context.Background(), 3*time.Second)
defer cancel() // 避免泄漏
go func() {
select {
case <-ctx.Done():
fmt.Println("收到取消信号:", ctx.Err())
}
}()
关键点:
在 HTTP 请求中控制超时:
client := &http.Client{}
req, _ := http.NewRequest("GET", "https://example.com", nil)
ctx, cancel := context.WithTimeout(context.Background(), 2*time.Second)
defer cancel()
req = req.WithContext(ctx)
resp, err := client.Do(req)
if err != nil {
log.Fatal(err)
}
在多阶段任务中协调取消:
ctx, cancel := context.WithCancel(context.Background()) defer cancel() go fetchUserData(ctx) go fetchConfig(ctx) // 某个条件触发取消 time.AfterFunc(1*time.Second, cancel)
每个子任务内部都应监听 ctx.Done() 并及时退出,避免 goroutine 泄漏。
使用 context 时需注意以下几点:
基本上就这些。掌握 context 的取消机制,能有效提升程序的可控性和资源利用率。
以上就是Golang context语法与取消信号实践的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号