go :"os/signal"源码解析

栏目: Go · 发布时间: 6年前

内容简介:最近在学习go语言,基本语法熟悉之后,想看一些开源项目,于是就找到了NSQ,在看NSQ源码的时候,对signal进行了阅读,一下内容仅供参考。

最近在学习 go 语言,基本语法熟悉之后,想看一些开源项目,于是就找到了NSQ,在看NSQ源码的时候,对signal进行了阅读,一下内容仅供参考。

linux信号量知识点

go :

  • 图中可以看到信号来一共是62个,32和33没有
  • 非实时信号都不支持排队,都是不可靠信号;实时信号都支持排队,都是可靠信号。
  • 1到31号都是不可靠信号

go 语言singnal的源码(部分)

type handler struct {
    mask [(numSig + 31) / 32]uint32
    }
    
    func (h *handler) want(sig int) bool {
        return (h.mask[sig/32]>>uint(sig&31))&1 != 0
    }

    func (h *handler) set(sig int) {
        h.mask[sig/32] |= 1 << uint(sig&31)
    }

    func (h *handler) clear(sig int) {
        h.mask[sig/32] &^= 1 << uint(sig&31)
    }
  • type handler struct :定义了处理信号量的数据结构,mask [(numSig + 31) / 32]uint32中numSig是65,所以就是一个2个元素的数组,元素类型是uint32位的,4字节
  • set函数中,mask数组的初始化都是0,uint(sig&31)是整数截取后5位,左移一位是因为信号量是从1开始的。因此运算完之后,前31个信号量存放在mask数组的第一个元素中,这个4字节的元素可以表示成32位的二进制, 0000,0000,0000,0000,0000,0000,0000,0000 ,从后往前,编号从0到31,如果信号量是1,则编号为1的位置置1。就像是有32个桶,每个桶都有一个编号,从0到31,如果有这个信号量的值,就在桶里放满水。
  • want函数是判断给定的整数,是不是这个62个信号量。
  • clear 利用&^,将对应位置清零

go语言这种处理方式阅读起来还是挺巧妙的,之前看得时候也是弄明白,现在记下来,希望能提供一点用处。

总结

  • linux信号量的知识储备不全,先获取了 linux 信号量的知识之后才搞明白为什么这么写的。
  • 源码这种事情,还是可以单独拿出来,针对看不懂的地方进行调试,快速的了解。

以上所述就是小编给大家介绍的《go :"os/signal"源码解析》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

游戏编程模式

游戏编程模式

Robert Nystrom / GPP翻组 / 人民邮电出版社 / 2016-9-1 / 61.4

游戏开发一直是热门的领域,掌握良好的游戏编程模式是开发人员的应备技能。本书细致地讲解了游戏开发需要用到的各种编程模式,并提供了丰富的示例。 全书共分20章,通过三大部分内容全面介绍了与游戏编程模式相关的各类知识点。首部分介绍了基础知识和框架;第二部分深入探索设计模式,并介绍了模式与游戏开发之间的关联;第三部分介绍了13种有效的游戏设计模式。 本书提供了丰富的代码示例,通过理论和代码示例......一起来看看 《游戏编程模式》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具

html转js在线工具
html转js在线工具

html转js在线工具