【C++】模拟实现多线程中的信号量

本文介绍了C++中二元信号量和一般信号量的概念,通过生产者消费者例子展示了二元信号量的使用,并讨论了如何将其转换为普通信号量。同时,给出了信号量的模拟实现代码,包括生产者和消费者线程的交互过程。
摘要由CSDN通过智能技术生成

信号量:

二元信号量和一般信号量

二元信号量是最简单的一种锁,适合那种被唯一线程访问的资源,而一般信号量就允许多线程并发的访问资源。

二元信号量类似于互斥量,但是有一点不同的是,互斥量只能被上锁的那个线程释放,通俗的说就是,哪个线程对互斥量加的锁,就由哪个线程来劲释放。

下面来举例证明上述言论,下面来个简单的生产者消费者的例子,拿二元信号量来实现:

 上述生产者和消费者分别有两个不同定义的信号量初值,生产者的信号量初值为1,消费者信号量初值为0,acquire方法是对信号量减一,release方法是对信号量进行加一。当信号量为0时,代表这个操作不可执行,例如semp = 0时,进入生产者线程且生产者不可再次生产(因为semp = 0),当消费者执行完最后执行release方法,对semp进行加一操作,然后再来一个轮回执行。

下面来看代码:

#include<iostream>
#include<semaphore>
#include<thread>
using namespace std;

int g_num = 0;

std::binary_semap
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值