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

本文探讨了信号量与互斥锁在定义和语义上的区别。信号量用于多线程同步,当一个线程完成任务后通过信号量通知其他线程。互斥锁则用于确保对临界资源的独占访问。互斥锁的加锁和解锁必须由同一线程执行,而信号量可以由不同线程释放和获取。互斥锁保证资源访问的唯一性,但不控制顺序;信号量则能确保线程执行的有序性。此外,条件变量在满足特定条件时可唤醒其他等待线程。
摘要由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)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值