四种进程或线程同步互斥的控制方法

12 篇文章 0 订阅

四种进程或线程同步互斥的控制方法
1、临界区:通过对多线程的串行化来访问公共资源或一段代码,速度快,适合控制数据访问。 
2、互斥量:为协调共同对一个共享资源的单独访问而设计的。 
3、信号量:为控制一个具有有限数量用户资源而设计。 
4、事 件:用来通知线程有一些事件已发生,从而启动后继任务的开始。

临界区(Critical Section)(同一个进程内,实现互斥
保证在某一时刻只有一个线程能访问数据的简便办法。在任意时刻只允许一个线程对共享资源进行访问。如果有多个线程试图同时访问临界区,那么在有一个线程进入后其他所有试图访问此临界区的线程将被挂起,并一直持续到进入临界区的线程离开。临界区在被释放后,其他线程可以继续抢占,并以此达到用原子方式操作共享资源的目的。

互斥量(Mutex)(可以跨进程,实现互斥
互斥量跟临界区很相似,只有拥有互斥对象的线程才具有访问资源的权限,由于互斥对象只有一个,因此就决定了任何情况下此共享资源都不会同时被多个线程所访问。当前占据资源的线程在任务处理完后应将拥有的互斥对象交出,以便其他线程在获得后得以访问资源。互斥量比临界区复杂。因为使用互斥不仅仅能够在同一应用程序不同线程中实现资源的安全共享,而且可以在不同应用程序的线程之间实现对资源的安全共享。 
互斥量与临界区的作用非常相似,但互斥量是可以命名的,也就是说它可以跨越进程使用。所以创建互斥量需要的资源更多,所以如果只为了在进程内部是用的话使用临界区会带来速度上的优势并能够减少资源占用量。

信号量(Semaphores)(主要是实现同步,可以跨进程
信号量对象对线程的同步方式与前面几种方法不同,信号允许多个线程同时使用共享资源,这与操作系统中的PV操作相同。它指出了同时访问共享资源的线程最大数目。它允许多个线程在同一时刻访问同一资源,但是需要限制在同一时刻访问此资源的最大线程数目。一般是将当前可用资源计数设置为最大资源计数,每增加一个线程对共享资源的访问,当前可用资源计数就会减1,只要当前可用资源计数是大于0的,就可以发出信号量信号。但是当前可用计数减小到0时则说明当前占用资源的线程数已经达到了所允许的最大数目,不能在允许其他线程的进入,此时的信号量信号将无法发出

事件(Event)(实现同步,可以跨进程
事件对象也可以通过通知操作的方式来保持线程的同步。并且可以实现不同进程中的线程同步操作。
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
进程(线程)同步互斥是指当多个进程(线程)同时运行时,它们之间可能会存在共享资源的竞争问题,而同步互斥的目的就是为了解决这些竞争问题。同步是指多个进程(线程)在执行过程中需要相互配合,才能保证程序的正确性和可靠性。互斥是指多个进程(线程)之间相互排斥,同一时刻只允许一个进程(线程)访问共享资源,其他进程(线程)必须等待,直到该进程(线程)访问结束。 常见的进程(线程)同步互斥方式有: 1. 信号量:信号量是一种计数器,用于保护多个进程(线程)对共享资源的访问。当进程(线程)想要访问共享资源时,会尝试获取信号量,如果当前信号量的值大于0,则允许访问;否则需要等待,直到有一个进程(线程)释放了信号量。 2. 互斥量:互斥量是一种特殊的信号量,它只有两个取值:0和1。当进程(线程)想要访问共享资源时,需要先尝试获取互斥量,如果当前互斥量的值为0,则表示该共享资源被占用,需要等待;如果当前互斥量的值为1,则表示该共享资源未被占用,可以访问,并将互斥量的值设置为0,防止其他进程(线程)同时访问。 3. 条件变量:条件变量是一种用于在多个进程(线程)之间传递消息的机制。当某个条件满足时,一个进程(线程)会通知其他等待该条件的进程(线程),使它们可以继续执行。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值