一个统一处理出错的技巧

package main

import (
	"fmt"
	"sync"
)

type WaitGroupWrapper struct {
	sync.WaitGroup
}

func (w *WaitGroupWrapper) Wrap(cb func()) {
	w.Add(1)
	go func() {
		cb()
		w.Done()
	}()
}

func test1() error {
	fmt.Println("test1")
	return nil
}
func test2() error {
	fmt.Println("test2")
	//return errors.New("test2 error")
	return nil
}
func main() {
	exitCh := make(chan error)
	var once sync.Once
	exitFunc := func(err error) {
		once.Do(func() {
			if err != nil {
				fmt.Println("error happen")
			}
			exitCh <- err //阻塞
		})
	}

	w := &WaitGroupWrapper{}
	w.Wrap(func() {
		exitFunc(test1())
	})
	w.Wrap(func() {
		exitFunc(test2())
	})

	err := <-exitCh
	if err != nil {
		fmt.Println(err)
		return
	}
	w.Wait()
	fmt.Println("nomal exit")
	return
}

两个函数都没出错,输出

test2
test1
nomal exit

如果test2改成return errors.New(“test2 error”),出错了,输出

test2
error happen
test1
test2 error

这里很奇怪的一个点,是exitfunc函数只会执行一次,谁先执行了,后面的就不会再执行了,莫非他是默认失败的函数一定比成功的函数先返回?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值