使用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)
}祝好
本文介绍使用Golang实现生产者与消费者模式的两种方法。一种是限定生产一定数量的数据,另一种则是持续不断地生产和消费数据。通过通道(channels)进行数据传递,并利用goroutines并发执行。
911

被折叠的 条评论
为什么被折叠?



