在Go 中建立無取消傳播的上下文副本
在Go 中使用上下文時,可能需要建立一個包含相同值但在取消方面行為獨立的現有脈絡的副本。例如,當您想要在回應 HTTP 請求後執行非同步任務時,就會發生這種情況,這可能比原始上下文的壽命更長。
傳統方法包括手動追蹤儲存在上下文中的所有可能值並建立一個新的上下文來複製這些值。然而,有一個更簡單、更易於管理的解決方案。
Go 1.21 向 context 套件引入了 WithoutCancel 函數。此函數允許您建立一個新的上下文,該上下文繼承原始上下文的所有值,但不受其取消的影響:
import "context" // WithoutCancel returns a context that is never canceled. func WithoutCancel(ctx context.Context) context.Context { return context.WithValue(context.Background(), context.NoCancel{}, struct{}{}) }
要使用WithoutCancel,只需按如下方式包裝原始上下文:
func Handler(ctx context.Context) (interface{}, error) { result := doStuff(ctx) newContext := context.WithoutCancel(ctx) go func() { doSomethingElse(newContext) }() return result }
現在,新的goroutine 將使用原始上下文的副本進行操作,當原始上下文被取消時,該副本不會被取消。這提供了管理非同步任務生命週期所需的靈活性和控制。
以上是如何在 Go 中建立上下文副本而不取消傳播?的詳細內容。更多資訊請關注PHP中文網其他相關文章!