go实现生产者和消费者

package main
 
import (
    "fmt"
    "sync"
    "time"
)
 
var (
    queue     = make(chan int, 5)  // 创建一个容量为5的缓冲区
    wg        sync.WaitGroup       // 用于等待程序结束
    producer  = 10                 // 生产者产出的数据量
    consumers = 2                  // 消费者的数量
)
 
// 消费者函数
func consumer(id int) {
    defer wg.Done()
    for {
        // 从channel中取数据,如果没有数据,会阻塞
        num, more := <-queue
        if more {
            fmt.Printf("Consumer %d consumes: %d\n", id, num)
        } else {
            fmt.Printf("Consumer %d exiting...\n", id)
            return
        }
    }
}
 
// 生产者函数
func producer() {
    for i := 1; i <= producer; i++ {
        queue <- i
        fmt.Printf("Producer produces: %d\n", i)
        time.Sleep(time.Second) // 模拟生产者生产数据的时间
    }
    close(queue) // 生产完毕,关闭channel
}
 
func main() {
    // 设置等待组的数量
    wg.Add(consumers)
    // 启动消费者
    for i := 1; i <= consumers; i++ {
        go consumer(i)
    }
    // 启动生产者
    go producer()
    // 等待所有的goroutines完成
    wg.Wait()
    fmt.Println("All tasks are done!")
}

相关推荐

  1. go实现生产者消费者

    2024-04-07 11:48:03       16 阅读
  2. go-zero整合Kafka实现消息生产消费

    2024-04-07 11:48:03       12 阅读
  3. 【Golang】Go 中的生产者-消费者模式

    2024-04-07 11:48:03       9 阅读
  4. C++生产者消费者问题实例

    2024-04-07 11:48:03       12 阅读
  5. 消费者——生产者

    2024-04-07 11:48:03       16 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-04-07 11:48:03       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-07 11:48:03       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-07 11:48:03       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-07 11:48:03       20 阅读

热门阅读

  1. 腾讯光子工作室群 一面 (30min)

    2024-04-07 11:48:03       16 阅读
  2. 如何使用Arduino IDE对STM32F103C8T6进行编程

    2024-04-07 11:48:03       15 阅读
  3. vue3+elementUiPlus+弹框

    2024-04-07 11:48:03       12 阅读
  4. 每日OJ题_回文串dp④_力扣132. 分割回文串 II

    2024-04-07 11:48:03       16 阅读
  5. https安全锁出现感叹号的原因

    2024-04-07 11:48:03       16 阅读
  6. redis的List详细介绍

    2024-04-07 11:48:03       13 阅读