golang context介绍

在 Go 语言中,context 是一个用于在 goroutines 之间传递上下文信息的包。它主要用于控制请求的生命周期和管理跨 API 边界的信号传递。以下是 context 的一些关键特性和用途:

1. 主要用途

  • 取消信号:允许在多个 goroutines 中发出取消信号,以便提前终止操作。
  • 超时控制:可以设置超时时间,使得操作在超时后自动取消。
  • 传递请求范围值:可以在上下文中传递请求范围的值,例如身份验证信息或请求ID。

2. 主要类型

  • Contextcontext.Context 是一个接口,定义了方法来获取值、检查是否被取消以及获取截止时间。
  • 背景上下文
    • context.Background():返回一个空的上下文,通常在主函数、初始化和测试中使用。
    • context.TODO():用于尚未确定上下文的场合,表示未来可能需要使用上下文。

3. 创建上下文

  • WithCancel:创建一个可以取消的上下文。
  • WithTimeout:创建一个具有超时的上下文。
  • WithDeadline:创建一个在特定时间点自动取消的上下文。
  • WithValue:创建一个可以存储键值对的上下文。

4. 示例

以下是一个简单的示例,展示如何使用 context

go 复制代码
package main

import (
    "context"
    "fmt"
    "time"
)

func main() {
    // 创建一个带有取消功能的上下文
    ctx, cancel := context.WithCancel(context.Background())
    defer cancel() // 确保在函数结束时取消上下文

    go func() {
        time.Sleep(2 * time.Second)
        cancel() // 2秒后取消上下文
    }()

    // 等待上下文被取消
    <-ctx.Done()
    fmt.Println("Context cancelled:", ctx.Err())
}

5. 注意事项

  • context 是不可变的:一旦创建,就不能修改。
  • 应避免将 context 作为普通参数传递,应该作为第一个参数。
  • 不应将 context 存储在结构体中或长时间保存。

总结

context 是 Go 中用于管理 goroutines 生命周期和信号传递的重要工具。它使得在并发编程中处理请求的取消、超时和传递值变得更加简单和安全。

相关推荐
用户8307196840826 分钟前
Spring Boot 集成 RabbitMQ :8 个最佳实践,杜绝消息丢失与队列阻塞
spring boot·后端·rabbitmq
小兔崽子去哪了17 分钟前
Java 自动化部署
java·后端
Selicens18 分钟前
git批量删除本地多余分支
前端·git·后端
哈密瓜的眉毛美22 分钟前
Java 基础补充:零基础学Java | Scanner 类详解
后端
ma_king23 分钟前
入门 java 和 数据库
java·数据库·后端
平平无奇的开发仔27 分钟前
Mybaitis 项目多模块多依赖xml加载classpath:和classpath*:的区别
后端
神奇小汤圆42 分钟前
MySQL的10种高级SQL,性能飞升
后端
AI探索者44 分钟前
LangGraph 人工干预:Human-in-the-loop 机制详解
后端
神奇小汤圆1 小时前
Java并发核心:你以为AQS很复杂?无非是"两个队列"和"一个状态"
后端
shark_chili1 小时前
Spring AI Alibaba 入门与实战:一文构建智能天气查询助手
后端