Golang基于Channel的生产消费模式实现

先贴代码,有错误请指正

package main

import (
	"log"
	"sync"
	"time"
)

var (
	task    chan int = make(chan int, 10)
	done    chan int = make(chan int, 10)
	wg_task sync.WaitGroup
	wg_done sync.WaitGroup
)

func produce(task_count int) {
	defer wg_task.Done()

	for i := 0; i < task_count; i++ {
		task <- i
		log.Printf("send task : [%d]", i)
	}
	close(task)
}

func consumer(i int) {
	defer wg_task.Done()
	for {
		v, ok := <-task
		log.Printf("recv task [%d]: [%d] [%v]", i, v, ok)
		if !ok {
			break
		}

		done <- v
		time.Sleep(20 * time.Millisecond)
	}
}

func consumer_done() {
	defer wg_done.Done()
	for {
		v, ok := <-done
		log.Printf("finished : [%d] [%v]", v, ok)
		if !ok {
			break
		}
	}
}

func main() {

	wg_task.Add(1)
	go produce(1000)

	for i := 0; i < 10; i++ {
		wg_task.Add(1)
		go consumer(i)
	}

	wg_done.Add(1)
	go consumer_done()

	wg_task.Wait()
	close(done)

	wg_done.Wait()
}

posted on   jobgeo  阅读(431)  评论(0编辑  收藏  举报

编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· winform 绘制太阳,地球,月球 运作规律
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示