GO chan select

本文介绍Go语言中的select关键字,它允许监听多个channel并在数据可用时进行处理。通过一个示例展示了如何创建并行处理两个channel,将接收到的值传递到worker channel,并在worker channel中打印这些值。此外,还提及了select与定时器的结合使用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

select功能:
可以在select中监听多个chan,哪个chan来了就处理哪个,这样的好处是可以对多个chan进行并行处理。
下面给出一个例子,例子的功能是:
1、创建两个chan并向其中每间隔1.5秒写入一个值,chan收到值后直接写入worker chan中
2、worker chan收到值直接输出
3、select中加入了一些定时器的用法,供参考

main.go

package main

import (
	"fmt"
	"time"
)

func createIntChan() chan int{
	c := make(chan int)
	i := 0
	go func() {
		for{
			time.Sleep(time.Millisecond*800)
			c <- i
			i++
		}
	}()
	return c
}

func createWork() chan string {
	worker := make(chan string)
	return worker
}
func inputWork(n int,worker chan string,chanName string)  {
	v := fmt.Sprintf( "the value is %d from chan %s",n,chanName)
	worker <- v
}
func main() {
	c1,c2 := createIntChan(),createIntChan()
	worker := createWork()

	tm := time.After(time.Second*10)
	tx := time.Tick(time.Second)
	for{
		select {
		//10秒后关闭应用
		case <-tm:
			fmt.Println("bye ...")
			return
		//schedule:每间隔两2秒打印一次
		case <-tx:
			fmt.Println("间隔2秒打印。。。")
		case n := <- c1:
			go inputWork(n,worker,"c1")
		case n := <-c2:
			go inputWork(n,worker,"c2")
		case v := <- worker:
			fmt.Println("out put from cache : ",v)
		//300毫秒没收到任何chan的值就打印这条
		case <-time.After(time.Millisecond*300):
			fmt.Println("time out")
		}
	}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值