Go语言编程:使用条件变量Cond和channel通道实现多个生产者和消费者模型

如题,使用条件变量Cond和channel通道实现多个生产者和消费者模型。Go语言天生带有C语言的基因,很多东西和C与很像,但是用起来 绝对比C语言方便。今天用Go语言来实现下多消费者和生产者模型。如果对C语言的多生产者和消费者模型感兴趣的可以看Linux系统编程:使用mutex互斥锁和条件变量实现多个生成者和消费者模型

代码实现

代码实现用了Cond条件变量和channel通道

package main

import (
	"fmt"
	"math/rand"
	"sync"
	"time"
)

var cond sync.Cond

//生产者
func produce(out chan<- int, nu int) {
	for {
		cond.L.Lock()
		//产品区满 等待消费者消费
		for len(out) == 3 {
			cond.Wait()
		}
		num := rand.Intn(1000)
		out <- num
		fmt.Printf("%dth ***producer produce***,num = %d,len(chan) = %d\n", nu, num, len(out))
		cond.L.Unlock()

		//生产了产品唤醒 消费者线程
		cond.Signal()
		//生产完了歇一会,给其他协程机会
		time.Sleep(time.Second)
	}
}

//消费者
func consume(in <-chan int, nu int) {
	for {
		cond.L.Lock()
		//产品区空 等待生产者生产
		for len(in) == 0 {
			cond.Wait()
		}
		num := <-in
		fmt.Printf("%dth ###consumer consume###,num = %d,len(chan) = %d\n", nu, num, len(in))
		cond.L.Unlock()
		cond.Signal()

		//消费完了歇一会,给其他协程机会
		time.Sleep(time.Millisecond * 500)
	}
}

func main() {
	//设置随机数种子
	rand.Seed(time.Now().UnixNano())
	quit := make(chan bool)
	//产品区 使用channel模拟
	product := make(chan int, 3)

	//创建互斥锁和条件变量
	cond.L = new(sync.Mutex)

	//5个消费者
	for i := 0; i < 5; i++ {
		go produce(product, i)
	}
	//3个生产者
	for i := 0; i < 3; i++ {
		go consume(product, i)
	}

	//主协程阻塞 不结束
	<-quit
}

运行效果



  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
pthread_cond是一种条件变量,它可以用于线程间的同步和通信。在多生产者和多消费者模型中,生产者线程负责生产数据,并将其放入共享队列中,而消费者线程则从队列中获取数据并进行处理。由于多个线程同时访问共享队列,因此需要使用pthread_cond来确保线程安全和同步。 以下是一些使用pthread_cond实现生产者和多消费者模型的步骤: 1. 定义共享队列和锁 在多生产者和多消费者模型中,共享队列是所有线程都可以访问的数据结构。为了避免多个线程同时访问队列而导致数据不一致,需要使用锁来保护队列。可以使用pthread_mutex_t类型的锁来实现。 2. 定义条件变量 条件变量用于通知线程某个事件已经发生,例如队列已经有数据可以被消费或者队列已经满了无法再生产数据。在使用条件变量之前,需要先定义它。 3. 生产者线程 生产者线程的任务是生产数据并将其放入共享队列中。当队列已满时,生产者线程需要等待条件变量通知。 4. 消费者线程 消费者线程的任务是从共享队列中获取数据并进行处理。当队列为空时,消费者线程需要等待条件变量通知。 5. 发送信号 当生产者线程向队列中放入数据时,需要向条件变量发送信号,以通知消费者线程有数据可以被消费。同样,当消费者线程从队列中取出数据时,需要向条件变量发送信号,以通知生产者线程有空间可以生产数据。 6. 等待信号 当生产者线程或消费者线程需要等待条件变量通知时,可以使用pthread_cond_wait函数来等待。pthread_cond_wait函数会释放锁,并使线程进入睡眠状态,直到有其他线程发送信号。 7. 销毁条件变量和锁 在程序结束时,需要销毁条件变量和锁来释放内存资源。 综上所述,使用pthread_cond实现生产者和多消费者模型需要定义共享队列和锁,定义条件变量实现生产者线程和消费者线程,发送信号和等待信号,以及销毁条件变量和锁。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值