• golang中context包学习


    • 摘要

    go语言中goroutine之间的关联关系,缺乏维护,在erlang中有专门的机制来保障新开仟程的生命周期,

    在go语言中,只能通过channel + select来实现,但不够直观,感觉很绕。

    Context 通常被译作 上下文 ,它是一个比较抽象的概念。在公司技术讨论时也经常会提到 上下文 。一般理解为程序单元的一个运行状态、现场、快照,而翻译中 上下 又很好地诠释了其本质,上下上下则是存在上下层的传递,  会把内容传递给  。在Go语言中,程序单元也就指的是Goroutine。

    context 包不仅实现了在程序单元之间共享状态变量的方法,同时能通过简单的方法,使我们在被调用程序单元的外部,通过设置ctx变量值,将过期或撤销这些信号传递给被调用的程序单元。

    • 源码剖析

    context包的接口

    //  context 包里的方法是线程安全的,可以被多个 goroutine 使用   
    type Context interface {              
        // 当Context 被 canceled 或是 times out 的时候,Done 返回一个被 closed 的channel     
        Done() <-chan struct{}       
     
        // 在 Done 的 channel被closed 后, Err 代表被关闭的原因  
        Err() error
     
        // 如果存在,Deadline 返回Context将要关闭的时间 
        Deadline() (deadline time.Time, ok bool)
     
        // 如果存在,Value 返回与 key 相关了的值,不存在返回 nil 
        Value(key interface{}) interface{}
    }
    

    我们不需要手动实现这个接口,context 包已经给我们提供了两个,一个是 Background(),一个是 TODO(),这两个函数都会返回一个 Context 的实例。只是返回的这两个实例都是空 Context。

      

  • 相关阅读:
    mapper.xml接收多个参数
    java循环调用多个timer定时器
    java执行cmd命令的两种方法
    java解压.ZIP .TAR等常用格式文件
    HDU2157 (水题)状态转移
    Codeforces Round #628 (Div. 2)C. Ehab and Path-etic MEXs(构造+树)
    POJ3735——mat乘法优化
    HDU5667——费马小定理
    UCF Local Programming Contest 2012(Practice) D. The Clock Algorithm
    嵌套递推——矩阵快速幂
  • 原文地址:https://www.cnblogs.com/hetonghai/p/6852144.html
Copyright © 2020-2023  润新知