Golang学习笔记:WaitGroup、Context、goroutine定时器及超时

2021-08-1907:23:15编程语言入门到精通Comments1,922 views字数 1153阅读模式

WaitGroup

WaitGroup 在 sync 包中,用于阻塞主线程执行直到添加的 goroutine 全部执行完毕。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/ymba/22092.html

Context

Context 是在 Go1.7 中移入标准库的。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/ymba/22092.html

Context 包不仅实现了在程序单元之间共享状态变量的方法,同时能通过简单的方法,使我们在被调用程序单元的外部,通过设置ctx变量值,将过期或撤销这些信号传递给被调用的程序单元。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/ymba/22092.html

goroutine的定时器及超时

这是两个有趣又实用的功能,在标准库 time 包里提供。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/ymba/22092.html

示例

源码

<!--more-->文章源自菜鸟学院-https://www.cainiaoxueyuan.com/ymba/22092.html

package main

import (
    "context"
    "fmt"
    "sync"
    "time"
)

func main() {
    ch := make(chan int)
    //定义一个WaitGroup,阻塞主线程执行
    var wg sync.WaitGroup
    //添加一个goroutine等待
    wg.Add(1)
    //goroutine超时
    go func() {
        //执行完成,减少一个goroutine等待
        defer wg.Done()
        for {
            select {
            case i := <-ch:
                fmt.Println(i)
            //goroutine内部3秒超时
            case <-time.After(3 * time.Second):
                fmt.Println("goroutine1 timed out")
                return
            }
        }
    }()
    ch <- 1
    //新增一个1秒执行一次的计时器
    ticker := time.NewTicker(1 * time.Second)
    defer ticker.Stop()
    //新增一个10秒超时的上下文
    background := context.Background()
    ctx, _ := context.WithTimeout(background, 10*time.Second)
    //添加一个goroutine等待
    wg.Add(1)
    go func(ctx context.Context) {
        //执行完成,减少一个goroutine等待
        defer wg.Done()
        for {
            select {
            //每秒一次
            case <-ticker.C:
                fmt.Println("tick")
            //内部超时,不会被执行
            case <-time.After(5 * time.Second):
                fmt.Println("goroutine2 timed out")
            //上下文传递超时信息,结束goroutine
            case <-ctx.Done():
                fmt.Println("goroutine2 done")
                return
            }
        }
    }(ctx)
    //等待所有goroutine执行完成
    wg.Wait()
}

执行结果

1
tick
tick
tick
goroutine1 timed out
tick
tick
tick
tick
tick
tick
tick
goroutine2 done
文章源自菜鸟学院-https://www.cainiaoxueyuan.com/ymba/22092.html
  • 本站内容整理自互联网,仅提供信息存储空间服务,以方便学习之用。如对文章、图片、字体等版权有疑问,请在下方留言,管理员看到后,将第一时间进行处理。
  • 转载请务必保留本文链接:https://www.cainiaoxueyuan.com/ymba/22092.html

Comment

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定