Go 编程: 应用级抽象之信号管控

栏目: IT技术 · 发布时间: 4年前

内容简介:在软件开发过程中,我们常常做的一件事,就是编写公用库,或是基础库。这个过程可以称之为以信号管控为例,在 Go 语言中管控进程信号,非常简单。只需要简单的 3 行代码即可完成管控:但在实际开发过程中,这些功能性的函数缺少了

在软件开发过程中,我们常常做的一件事,就是编写公用库,或是基础库。这个过程可以称之为 应用级抽象 。应用级抽象的好处在于,接口主要面向应用,所以在适配度远远超过功能性接口。

以信号管控为例,在 Go 语言中管控进程信号,非常简单。只需要简单的 3 行代码即可完成管控:

package main

import "os/signal"

func main() {
    //信号接收 channel
    sigCh := make(chan os.Signal, 1)
    
    //监听信号(所有信号)
    signal.Notify(sigCh)

    //信号触发
    sig := <-sigch
    //TODO
}

但在实际开发过程中,这些功能性的函数缺少了 应用级抽象 ,想要像搭积木一样构建应用程序多少有些不便。所以,花了点时间做一下应用级别抽象,方便以后使用。

既然是应用级抽象,就从应用层面入手,首先给这块抽象的积木,按照功能命个名,就叫 Capture 好了。

//信号捕获器
type Capture struct{
  //TODO
}

既然是信号捕获, 在创建 Capture 时需要定义具体信号的触发操作,将具体 <信号,触发函数> ,取个英文名 Trap 。那么,在创建 Capture 时,就可以做为参数传进去。同时, Capture 必须处于服务状态,才可以监听并触发信号操作,所以需要提供一个 Capture.Serve 函数。最终希望的应用级接口就是这样:

package main

import (
    "context"
    "log"
    "syscall"

    "github.com/x-mod/sigtrap"
)

func main() {
  ctx, cancel := context.WithCancel(context.Background())
  
    capture := sigtrap.New(
        sigtrap.Trap(syscall.SIGINT, sigtrap.Handler(cancel)),
        sigtrap.Trap(syscall.SIGTERM, sigtrap.Handler(cancel)),
    )
    defer capture.Close()
    log.Println("sigtrap: waiting ...")
    log.Println("sigtrap:", capture.Serve(ctx))
}

具体的 Capture 实现也非常的简单,可以直接参考项目源码: github.com/x-mod/sigtrap .很多类似这样简单 工具 包均没有太多的技术难度,封装主要目的就是在做 应用级抽象

这个包主要用在我的另外一个应用级抽象包: x-mod/routine 中。它主要抽象的是, main 函数与 go routine 协程控制,具体实现功能以后抽时间分享,感兴趣的话可以参考项目源码。

更多 应用级抽象 工具包目录在这个仓库: github.com/x-mod/index .

基础库

网络库


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

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

O2O进化论

O2O进化论

板砖大余、姜亚东 / 中信出版社 / 2014-5 / 49

在互联网的1.0时代,Online的商业和Offline的商业就像是两条平行线,没有交汇点,在移动浪潮下,他们正在交汇,这就是O2O(Online to Offline)。于是,人们认为:O2O就是线下将线上作为销售前台。结论是对的,但并非简单相加就可以达到。人们已经进入数据革命时期,O2O是线上和线下全流通的数据化工具,电子商务就是非数据商品的数据化。其次,O2O还是一种竞争格局。这决定了以O2......一起来看看 《O2O进化论》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

在线进制转换器
在线进制转换器

各进制数互转换器

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

在线 XML 格式化压缩工具