Golang 使用 select 切换协程

在Go语言中,select关键字用于提供一种方法,可以监听多个通道操作,并且当其中任何一个通道就绪可以进行读写的时候,就会进行对应的读写操作。

下面是一个使用select来切换协程的例子:




package main
 
import (
    "fmt"
    "time"
)
 
func worker(id int, delay time.Duration) <-chan int {
    c := make(chan int)
    go func() {
        time.Sleep(delay * time.Millisecond)
        c <- id
    }()
    return c
}
 
func main() {
    c1 := worker(1, 200*time.Millisecond)
    c2 := worker(2, 100*time.Millisecond)
    c3 := worker(3, 300*time.Millisecond)
 
    for i := 0; i < 3; i++ {
        select {
        case r := <-c1:
            fmt.Println("worker", r, "executed @", time.Now())
        case r := <-c2:
            fmt.Println("worker", r, "executed @", time.Now())
        case r := <-c3:
            fmt.Println("worker", r, "executed @", time.Now())
        }
    }
    fmt.Println("All workers executed @", time.Now())
}

在这个例子中,我们创建了3个worker协程,每个worker协程都有一个对应的通道。然后在main函数中,我们使用select语句来监听这三个通道。当任意一个通道有消息可以读取时,就会执行对应的case语句。这样就实现了协程之间的切换。

这个例子的输出可能像这样:




worker 2 executed @ 2020-04-10 18:52:05.573125 +0000 UTC m=+100.000011185
worker 1 executed @ 2020-04-10 18:52:07.575 +0000 UTC m=+200.000012285
worker 3 executed @ 2020-04-10 18:52:08.575 +0000 UTC m=+300.000012285
All workers executed @ 2020-04-10 18:52:08.575 +0000 UTC m=+300.000012285

这个例子展示了如何使用select语句来控制协程的执行顺序。每个worker协程模拟了一个任务,通过延迟来模拟任务的执行时间,然后通过select语句来决定哪个任务先执行。

最后修改于:2024年08月27日 18:58

评论已关闭

推荐阅读

Vue中使用mind-map实现在线思维导图
2024年08月04日
VUE
Web前端最全Vue实现免密登录跳转的方式_vue怎么样不登录返回首页,最强技术实现
2024年08月04日
VUE
vue3 项目搭建教程(基于create-vue,vite,Vite + Vue)
2024年08月04日
VUE
Vue-颜色选择器实现方案——>Vue-Color( 实战*1+ Demo*7)
2024年08月04日
VUE
Vue项目卡顿慢加载?这些优化技巧告诉你!_vue数据多渲染卡顿
2024年08月04日
VUE
vue中的keep-alive详解与应用场景
2024年08月04日
VUE
Vue、React实现excel导出功能(三种实现方式保姆级讲解)
2024年08月04日
vue-office/docx插件实现docx文件预览
2024年08月04日
VUE
java调用js文件的两种方法(支持V8引擎)
2024年08月04日
JavaScript:解决计算精度问题/mathjs/bignumber.js/big.js/decimal.js
2024年08月04日
两周从爬虫小白变大神 _yjs_js_security_passport
2024年08月04日
JS笔记(对象、函数、数组)
2024年08月04日
Markdown.js:强大的纯JavaScript Markdown解析器
2024年08月04日
Vue项目:js模拟点击a标签下载文件并重命名,URL文件地址下载方法、请求接口下载文件方法总结。
2024年08月04日
vue 父组件怎么获取子组件里面的data数据
2024年08月04日
VUE
个人开发实现AI套壳网站快速搭建(Vue+elementUI+SpringBoot)
2024年08月04日
el-table 表格封装并改造实现单元格可编辑
2024年08月04日
none
nodejs环境下创建vue项目、SSH密钥登陆!!!
2024年08月04日
vue+quill+element-ui实现视频、图片上传及缩放保姆级教程,轻松使用富文本
2024年08月04日
【three.js】22. Imported Models导入模型
2024年08月04日