select语句用于多路channel通信,每个case必须是channel操作,多个就绪时随机执行一个,避免饥饿问题。

Go语言中的
select
select
select
select {
case v := <-ch1:
// 处理从ch1接收到的数据
case ch2 <- data:
// 向ch2发送数据
default:
// 当没有channel就绪时执行
}
特点:
select
default
default
常见场景是同时从多个channel接收数据,哪个先准备好就处理哪个。
立即学习“go语言免费学习笔记(深入)”;
package main
<p>import (
"fmt"
"time"
)</p><p>func fetchData(ch chan string, data string, delay time.Duration) {
time.Sleep(delay)
ch <- data
}</p><p>func main() {
ch1 := make(chan string)
ch2 := make(chan string)</p><pre class='brush:php;toolbar:false;'>go fetchData(ch1, "来自服务1的数据", 100*time.Millisecond)
go fetchData(ch2, "来自服务2的数据", 200*time.Millisecond)
select {
case msg := <-ch1:
fmt.Println("收到:", msg)
case msg := <-ch2:
fmt.Println("收到:", msg)
}
// 总是先打印来自服务1的数据}
防止程序在channel操作上无限等待,可结合
time.After
select {
case msg := <-ch:
fmt.Println("正常收到:", msg)
case <-time.After(2 * time.Second):
fmt.Println("超时:2秒内未收到数据")
}
这种模式在处理网络请求或外部服务调用时非常实用,避免程序卡死。
使用
default
ch := make(chan int, 1)
ch <- 1
<p>select {
case ch <- 2:
fmt.Println("成功发送2")
default:
fmt.Println("channel已满,无法发送")
}</p><p>select {
case v := <-ch:
fmt.Println("收到:", v)
default:
fmt.Println("channel为空,无数据可取")
}</p>这种写法适合在循环中轮询channel状态,常用于状态监控或资源调度。
基本上就这些。select配合channel是Go并发编程的核心技巧之一,掌握它能写出更健壮的并发程序。
以上就是Golangselect语句配合channel使用示例的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号