一、前沿
在进程/线程并发执行的时候,进程/线程之间存在协作的关系,即互斥或同步。接下来这篇主要讲述,线程的同步机制
同步概念:所谓同步,就是并发进程/线程在一些关键点上可能需要互相等待与互通消息,这种相互制约的等待与互通信息称为进程/线程同步。
二、线程同步机制
(1)互斥量:互斥对象只有⼀个,可以保证公共资源不被多个线程访问
(2)信号量:整型变量,允许多个线程同⼀时刻访问同⼀资源,但是需要限制访问的线程数目
(3)临界区:对临界资源进⾏访问的那段程序代码;多个线程访问⼀个独占性共享资源,拥有 临界区的对象被保护起来,其他想访问临界区的线程被挂起
(4)事件/信号:通知/唤醒线程有时间发生
(5)屏障:用户协调多个线程并行工作的同步机制。屏障允许每个线程等待,直到所有的合作线程都到达某一点,然后所有线程都从该点继续执行。
其实,还有锁机制也能实现线程同步,比如读写锁、互斥锁、自旋锁等,本文主要针对以上五种线程同步机制进行叙述hh,见谅啦
三、五种线程同步机制区别
优点 | 缺点 | |
临界区 | 保证某⼀时刻只有⼀个线程访问 的简便⽅法,速度快 | 只能⽤来同步本进程内的线程 |
互斥量 | 可以在不同进程的线程之间实现 资源的安全共享;和临界区很相似,但是互斥量是可以命名的 | 创建耗费资源更多 |
信号量 | 适⽤于Socket程序中的同步 | 必须有公共内存,不适合分布式操作 系统,不易管理可控制、易出错 |
事件/信号 | 可以实现不同进程中线程的同步 | |
屏障 | 实现多个线程并行工作的同步 | 需要等到所有线程完成工作 |
其实,线程同步就是相互制约的等待与互通信息。这其中就涉及到进程/线程间通信,锁、信号量、信号都可以用于线程间的同步。