首页 > 解决方案 > 如何在不派生的情况下复制上下文对象

问题描述

我想制作一个上下文对象的副本——确切地说是一个请求上下文,然后在一个单独的 go 例程中使用它。

问题是,如果我在此请求的 HTTP 处理程序完成后使用派生请求上下文context.WithCancel(reqCtx),不仅原始请求上下文将被取消,而且请求上下文的副本也将被取消。

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

标签: httpgocopycancellation

解决方案


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

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}

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


推荐阅读