多进程同步机制一般有四种方式:
- 临界区(Critical Section)
- 互斥量(Mutex)
- 信号量(Semaphore)
- 事件(Event)
- 临界区是指一段代码,这段代码是用来访问临界资源的。临界资源可以是硬件资源,也可以是软件资源。但它们有一个特点就是,一次仅允许一个进程或线程访问。当有多个线程试图同时访问,但已经有一个线程在访问该临界区了,那么其他线程将被挂起。临界区被释放后,其他线程可继续抢占该临界区。
- 互斥量的用途和临界区非常类似,线程拥有 互斥量(mutex) 就好象线程进入 临界区(critical section) 一样,但是它牺牲速度以增加弹性。一旦没有任何线程拥有那个 互斥量mutex,这个 互斥量mutex 便处于激发状态。
互斥量与临界区的区别是:
1. 互斥量 操作要比 临界区 费时的多。
2. 互斥量 可以跨进程使用,临界区 则只能在同一进程中使用。
3. 等待一个 互斥量 时,你可以指定"结束等待"的时间长度,而 临界区 则不行。