Golang 提供了优雅的并发方式, 继续使用生产者/消费者模型解决并发是比较 low 的方法. Anyway, 上代码.
package main
import (
"fmt"
"math/rand"
"time"
)
func productor(channel chan<- string) {
for {
channel <- fmt.Sprintf("%v", rand.Float64())
time.Sleep(time.Second * time.Duration(1))
}
}
func customer(channel <-chan string) {
for {
message := <-channel // 此处会阻塞, 如果信道中没有数据的话
fmt.Println(message)
}
}
func main() {
channel := make(chan string, 5) // 定义带有5个缓冲区的信道(当然可以是其他数字)
go productor(channel) // 将 productor 函数交给协程处理, 产生的结果传入信道中
customer(channel) // 主线程从信道中取数据
}
Output:
0.6046602879796196
0.9405090880450124
0.6645600532184904
0.4377141871869802
0.4246374970712657
...
有疑问加站长微信联系(非本文作者)