1 Star 0 Fork 0

h79/goutils

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
run.go 1.08 KB
一键复制 编辑 原始数据 按行查看 历史
huqiuyun 提交于 2022-11-03 00:43 . 主协程
package system
import (
"gitee.com/h79/goutils/common"
"os"
"os/signal"
"sync"
"syscall"
"time"
)
func Run() {
sys := Exit()
for {
select {
case <-sys.Done():
return
}
}
}
type Chan struct {
S chan os.Signal
}
func (c *Chan) Done() <-chan os.Signal {
return c.S
}
func Exit() *Chan {
s := &Chan{S: make(chan os.Signal)}
signal.Notify(s.S, os.Interrupt, os.Kill, syscall.SIGTERM, syscall.SIGQUIT)
return s
}
func Quit() {
timeout := time.After(2 * time.Second)
select {
case <-timeout:
return
}
}
type mainRun struct {
ev *Event
wg sync.WaitGroup
}
var (
mRun *mainRun
once sync.Once
)
func Main() *mainRun {
once.Do(func() {
mRun = &mainRun{
ev: NewEvent(),
}
})
return mRun
}
// Run self =true 表示主协程,子协程,select Main().Done
func (m *mainRun) Run(self bool, fn func()) {
m.wg.Add(1)
go func() {
defer m.wg.Done()
defer common.Recover()
defer func() {
if !self {
return
}
m.ev.Fire()
}()
fn()
}()
}
func (m *mainRun) Done() <-chan struct{} {
return m.ev.Done()
}
func (m *mainRun) Wait() {
m.wg.Wait()
}
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/h79/goutils.git
git@gitee.com:h79/goutils.git
h79
goutils
goutils
v1.2.21

搜索帮助