golang 的 channel 实现 生产者/消费者 模型

Posted exman

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了golang 的 channel 实现 生产者/消费者 模型相关的知识,希望对你有一定的参考价值。

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) // 主线程从信道中取数据
}

 

以上是关于golang 的 channel 实现 生产者/消费者 模型的主要内容,如果未能解决你的问题,请参考以下文章

[golang]单向channel的应用“生产消费者模型”

用生产者消费者理解golang channel

golang channel多生产者和多消费者实例

Golang channel 用法与实现原理

Golang channel源码分析

golang channel 使用总结