线程同步——信号量和互斥锁的区别

文章目录两者在定义上的区别两者在语义上的区别信号量实现同步互斥锁实现同步条件变量实现同步条件变量满足之后唤醒其他线程加锁两者在定义上的区别信号量是用在多线程同步上的,一个线程完成了某一个动作就通过信号量告诉别的线程,别的线程就可以进行某些动作,如果所有的线程都在(sem_wait),就会阻塞。互斥锁是用在多线程的互斥的,对于临界资源的访问,需要互斥进行。也就是说当一个线程占用了一个资源的时...
摘要由CSDN通过智能技术生成

两者在定义上的区别

  • 信号量是用在多线程同步上的,一个线程完成了某一个动作就通过信号量告诉别的线程,别的线程就可以进行某些动作,如果所有的线程都在(sem_wait),就会阻塞。
  • 互斥锁是用在多线程的互斥的,对于临界资源的访问,需要互斥进行。也就是说当一个线程占用了一个资源的时候,别的线程就无法访问,直到这个互斥锁被打开。通常锁和信号量是同时使用的,我们会在接下来的例子中给大家进行演示。
  • 互斥量的加锁和解锁必须由同一线程分别对应使用,信号量可以由一个线程释放,另一个线程得到。
  • 互斥锁(Mutex)保证了使用资源线程的唯一性和排他性,但是无法限制资源释放后其他线程申请的顺序问题,所以是无序的。
  • 信号量(Semaphore)一般就是互斥的(有些读的资源是可以同时进行分配的),其保证了线程执行的有序性。

两者在语义上的区别

  • 信号量的的value>=0
  • 互斥锁的valude可以为负数

信号量实现同步

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<unistd.h>
#include<assert.h>
#include<pthread.h>
#include<semaphore.h>

sem_t sem;
void *thread_fun(void *arg)
{
   

	int i=0;
	for(;i<5;i++)
	{
   
   	   sem_wait(&sem);
		write(1,"B",1);
		int n=rand()%3;
		sleep(n);

		write(1,"B",1);
	    sem_post(&sem);
	    
		n=rand()%3;
		sleep(n);
	}

}

int main()
{
   
	pthread_t id;
    sem_init(&sem,0,1);//初始化信号量
	int i=0;
	for(;i<5;i++)
	{
   
	    sem_wait(&sem)
  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值