golang生产者与消费者
发布时间:2020-12-16 19:17:15 所属栏目:大数据 来源:网络整理
导读:使用golang可以很容易实现,生产者与消费者功能。 实现一:(只生产一定数量数据) //写入专用通道//一次写10条func produce(p chan- int) {for i := 0; i 10; i++ {p - i//主线程不能产生死锁,所以此处报错fmt.Println("send:",i)}}//消费专用通道//一次只
使用golang可以很容易实现,生产者与消费者功能。 实现一:(只生产一定数量数据) //写入专用通道 //一次写10条 func produce(p chan<- int) { for i := 0; i < 10; i++ { p <- i //主线程不能产生死锁,所以此处报错 fmt.Println("send:",i) } } //消费专用通道 //一次只取10条 func consumer(c <-chan int) { for i := 0; i < 10; i++ { v := <-c fmt.Println("receive:",v) } } 调用: ch := make(chan int) //只生产和消费10条记录 go produce(ch) go consumer(ch) 实现二:(自动生产与消费) //自动消费 func autoConsumer(ch <-chan int) { for{ select { case ws:=<-ch: fmt.Println( "fmt print",ws) default: time.Sleep(1000*time.Millisecond) } } } 调用: ch := make(chan int) //持续生产与消费,high起来 go func() { for{ //不断生产,一次10条 produce(ch) } }() go autoConsumer(ch) 注意:为了保持主进程程不死掉,在main函数最下面加上这句。 for { //心跳 time.Sleep(time.Second) }祝好 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |