😥 整理不易,此资源只针对正式星主开放,
还请入驻星球后再来观看。

GOLANG ROADMAP

阅读模式

  • 沉浸
  • 自动
  • 日常
首页
Go学习
  • Go学院

    • Go小课
    • Go小考
    • Go实战
    • 精品课
  • Go宝典

    • 在线宝典
    • B站精选
    • 推荐图书
    • 精品博文
  • Go开源

    • Go仓库
    • Go月刊
  • Go下载

    • 视频资源
    • 文档资源
Go求职
  • 求职服务

    • 内推互助
    • 求职助力
  • 求职刷题

    • 企业题库
    • 面试宝典
    • 求职面经
Go友会
  • 城市
  • 校园
推广返利 🤑
实验区
  • Go周边
消息
更多
  • 用户中心

    • 我的信息
    • 推广返利
  • 玩转星球

    • 星球介绍
    • 角色体系
    • 星主权益
  • 支持与服务

    • 联系星主
    • 成长记录
    • 常见问题
    • 吐槽专区
  • 合作交流

    • 渠道合作
    • 课程入驻
    • 友情链接
author-avatar

GOLANG ROADMAP


首页
Go学习
  • Go学院

    • Go小课
    • Go小考
    • Go实战
    • 精品课
  • Go宝典

    • 在线宝典
    • B站精选
    • 推荐图书
    • 精品博文
  • Go开源

    • Go仓库
    • Go月刊
  • Go下载

    • 视频资源
    • 文档资源
Go求职
  • 求职服务

    • 内推互助
    • 求职助力
  • 求职刷题

    • 企业题库
    • 面试宝典
    • 求职面经
Go友会
  • 城市
  • 校园
推广返利 🤑
实验区
  • Go周边
消息
更多
  • 用户中心

    • 我的信息
    • 推广返利
  • 玩转星球

    • 星球介绍
    • 角色体系
    • 星主权益
  • 支持与服务

    • 联系星主
    • 成长记录
    • 常见问题
    • 吐槽专区
  • 合作交流

    • 渠道合作
    • 课程入驻
    • 友情链接
  • Go真实面试题汇总系列

    • Go基础篇
  • 宝典内容

    • 76. runtime提供常见的方法
    • 90. golang支持哪些并发机制
    • 97. go并发机制
    • 101. go语言怎么做的连接复用,怎么支持的并发请求,go的netpoll是怎么实现的像阻塞read一样去使用底层的非阻塞read
    • 107. go用共享内存的方式实现并发如何保证安全?
    • 115. 讲一讲 Golang 的并发控制
    • 178. golang中Context的使用场景
    • 179. context 的数据结构
    • 190. Golang 怎么在并发编程中等待多个 goroutine 结束?
    • 275. schedulerc的实现细节
    • 283. 说一下reflect
    • 284. 有很多sync_recv状态是发生了什么
    • 302. go实现一个并发限制爬虫
    • 310. 两个协程交替打印一个数组,使数组中的数据按顺序输出
    • 313. 一组协程完成后需要通知其他协程,可以怎么办?
    • 317. 从运行速度来讲,go的并发模型channel和goroutine
    • 319. sync.Once如何实现线程安全
    • 326. go 同步、channel的实现
    • 333. golang怎么协调并发协程的调度
    • 337. 介绍一下 Go 的 context
    • 352. 如何实现只开100个协程
    • 365. 有生产者和消费者应该在哪里关闭通道?
    • 381. golang除了goroutine还有什么处理并发的方法
    • 384. 给定n个并发量,并发处理数组
    • 404. context上下文控制
    • 409. go 多协程怎么同步
    • 413. go 怎么控制查询timeout (context)
    • 419. 怎么理解“不要用共享内存来通信,而是用通信来共享内存”
    • 439. Context 包的实现
    • 445. 协程间通信
    • 450. 写个channel相关的题,并发模型,爬虫url,控制并发量
    • 457. Go 并发优秀在哪里,需要通过实际的测试,benchmark等说明
    • 462. Go 高并发的特点
    • 469. go waitgroup 的坑

😥 整理不易,此资源只针对正式星主开放,
还请入驻星球后再来观看。

337. 介绍一下 Go 的 context


企业题库解析小组

题目来源:知乎

答案:自由

Context 就像糖葫芦中的竹签子 😃 它的作用是在上下文中传递除了业务参数之外的额外信息,这个额外信息是为了全局而考虑使用的,例如在微服务业务中,我们需要整个业务链条整体的超时时间信息。不过 go 标准库中的 Context 还提供了超时 Timeout 和 Cancel 机制。总的来说,在下面这些场景中,可以考虑使用 Context:

  • 上下文信息传递
  • 控制子 goroutine 的运行
  • 超时控制的方法调用
  • 可以取消的方法调用 Context 是一个可以帮助我们实现多 goroutine 协作流程的同步工具。我们还可以通过 Context 传达撤销信号与传递数据。Context 的实际值大体上分为三种:根 Context 值、可撤销的 Context 值和含数据的 Context 值。所有的 Context 值共同构成了一颗上下文树,这棵树的作用域是全局的,而根 Context 值就是这棵树的根,它是全局唯一的,并且不提供任何额外的功能。可撤销的 Context 值还可以分为:只可手动撤销的 Context 值,和可以定时撤销的 Context 值。可以通过生成它们时得到的撤销函数来对其进行手动的撤销。对于定时撤销的 Context 值必须在生成时就完全确定,并且不能更改,不过我们可以在过期时间达到之前,对其进行手动的撤销,一旦撤销函数被调用,撤销信号就会立即被传达给对应的 Context 值并由该值的 Done 方法返回的接收通道表达出来。“撤销”这个操作是 Context 值能够协调多个 goroutine 的关键所在。撤销信号会沿着上下文树叶子节点方向传播。含数据的 Context 可以携带数据。每个值都可以存储一对键和值。