如何复制Context对象而不派生

问题描述 投票:0回答:2

我想复制一个上下文对象 - 准确地说是一个请求上下文,并稍后在单独的 go 例程中使用它。

问题是,如果我使用

context.WithCancel(reqCtx)
派生请求上下文,一旦此请求的 HTTP 处理程序完成,不仅原始请求上下文将被取消,而且请求上下文的副本也将被取消。

我希望能够复制原始请求上下文,并且在 HTTP 处理程序完成执行后不让它被原始上下文取消。

http go copy cancellation
2个回答
13
投票

以下是如何创建一个使用其他上下文中的值但不使用取消的上下文:

type valueOnlyContext struct{ context.Context }
func (valueOnlyContext) Deadline() (deadline time.Time, ok bool) { return }
func (valueOnlyContext) Done() <-chan struct{} { return nil }
func (valueOnlyContext) Err() error { return nil }

像这样使用它:

 ctx := valueOnlyContext{reqCtx}

使用不取消的值可能超出了 context 包的设计意图。如果包的设计者认为这是一件好事,我会期望他们将以上内容捆绑在上下文包函数中。


0
投票

context.WithoutCancel在1.21.0版本中添加

© www.soinside.com 2019 - 2024. All rights reserved.