Go 中的上下文提供了一种机制来传递任意值以及请求并跟踪取消。默认情况下,所有上下文共享相同的取消机制。但是,某些场景可能需要将上下文传播与取消解耦。
考虑一个在请求生命周期之外执行任务的 HTTP 处理程序。返回响应后,处理程序可以在 goroutine 中启动异步任务。此任务可能需要访问上下文值,但如果原始请求上下文被取消,则不得终止。
Go 1.21 中引入了WithoutCancel,提供了一种简单的方法创建非取消上下文。使用此方法,我们可以获得原始上下文的副本,其中包含其所有存储值,但与其取消状态无关。
在 Go 1.21 之前,自定义非取消上下文的实现是必要的。关键是创建一个满足 context.Context 接口的类型并重写以下方法以防止取消:
此外,实现必须存储原始上下文并委托 Value() 调用来检索存储的值。
import ( "context" "github.com/mypackage/mycontext" ) func Handler(ctx context.Context) (interface{}, error) { result := doStuff(ctx) newContext := mycontext.WithoutCancel(ctx) go func() { doSomethingElse(newContext) }() return result }
通过了解不可取消上下文背后的原理并利用可用的工具,开发人员可以创建自定义解决方案或利用 Go 的内置功能来实现所需的上下文传播而无需取消。
以上是如何在没有取消传播的情况下使用 Go 中的上下文?的详细内容。更多信息请关注PHP中文网其他相关文章!