• Golang 协程控制关闭


    部分代码参考:https://zhuanlan.zhihu.com/p/26695984  

    这边文章的的


    package main

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

    func main() {
    ctx := context.Background()
    ctx, cancel := context.WithCancel(ctx)
    go Proc(ctx, 1)
    go Proc(ctx, 2)
    go Proc(ctx, 3)
    go Proc(ctx, 4)

    time.Sleep(time.Second / 10)
    cancel()

    time.Sleep(time.Second)
    }

    func Proc(ctx context.Context, n int) {
    for {
    select {
    case <-ctx.Done():
    return
    default:
    fmt.Printf("Proc-%d ", n)
    }
    }
    }


    这种形式的协程关闭和  自己写的区别在于   自己写的话自己要记录下协程的数量,关闭的chan等等

    这种比较省事儿,不过用法还是有点局限性的,比如协程里面没有 for{select } 这种结构的时候就比较尴尬了。

    不过这种方法用在  递归调用的时候  相当好用的   就是  go func(    go func1(  go func2()))   这种一个协程调用另一个协程一直这样的时候发现有问题了,就可以一个cancel()全部退出。
    ————————————————
    版权声明:本文为CSDN博主「____Luke」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    原文链接:https://blog.csdn.net/soekchl521/article/details/72420535

  • 相关阅读:
    读REDIS数据结构
    一致性哈希虚节点解决雪崩问题
    TCP的建立和关闭
    nginx和apache的比较
    进程和线程的区别
    acm过河卒
    搭建centos7 的php环境
    navicat 中 oracle数据传输到mysql上
    安装虚拟机精简版centos7
    整合tomcat的一些配置
  • 原文地址:https://www.cnblogs.com/ExMan/p/14693870.html
Copyright © 2020-2023  润新知