go channel练习

透过 go channel练习

  1. 透过goroutine 跑20个job
  2. 显示各个job的完成情况
  3. 使用errChan job发生错误跳出main func
  4. 通过 finishChan 通知全部job完成
  5. 设置超时机制
/**
 * @ClassName main
 * @Description //TODO 
 * @Author liwei
 * @Date 2021/4/12 21:30
 * @Version example V1.0
 **/

package main

import (
    "fmt"
    "log"
    "math/rand"
    "sync"
    "time"
)

func main()  {
    outChan:=make(chan  string,100)
    finishChan:=make(chan  struct{})
    errChan:=make(chan error,100)
    wg:=sync.WaitGroup{}
    wg.Add(20)
    for i:=0;i<=20 ;i++  {//透过goroutine 跑20个job
        go func(val int ,wg *sync.WaitGroup,out chan string,err  chan  error) {
            time.Sleep(time.Duration(rand.Int31n(1000))*time.Millisecond)
            out<-fmt.Sprintf("finish job id:%d",val)
            //if val==15{
            //  err<-errors.New("fail job in 15")
            //}
            wg.Done()
        }(i,&wg,outChan,errChan)
    }

    go func() {
        wg.Wait()
        close(finishChan)
    }()

Loop :
    for  {
        select {
        case out:=<-outChan: //显示各个job的完成情况
            log.Print(out)
        case err:=<-errChan://出现错误执行
            log.Print(err)
            break Loop
        case <-finishChan: //完成执行
            log.Print("close finishChan")
            break  Loop
        case <-time.After(100*time.Millisecond): //超时执行
            log.Print("timeOut")
            break Loop
        }
    }

}

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 夜莺2517阅读 127,752评论 1 9
  • 版本:ios 1.2.1 亮点: 1.app角标可以实时更新天气温度或选择空气质量,建议处女座就不要选了,不然老想...
    我就是沉沉阅读 6,939评论 1 6
  • 我是黑夜里大雨纷飞的人啊 1 “又到一年六月,有人笑有人哭,有人欢乐有人忧愁,有人惊喜有人失落,有的觉得收获满满有...
    陌忘宇阅读 8,588评论 28 53
  • 兔子虽然是枚小硕 但学校的硕士四人寝不够 就被分到了博士楼里 两人一间 在学校的最西边 靠山 兔子的室友身体不好 ...
    待业的兔子阅读 2,634评论 2 9