多线程的同步互斥
2014-09-22 17:25
141 查看
基本有四种控制方法:
临界区,互斥量,信号量和事件。
临界区Critical Section:
保证某一时刻,只有一个线程能访问数据的简便方法。当有一个程序在进入临界区后,其他试图访问这个临界区的线程都会被挂起,直到进入临界区的线程离开。
互斥量 Mutex :
与临界区相似,只有拥有互斥对象的线程才具有访问资源的权限,由于互斥对象只有一个,决定了任何情况下此共享资源都不会被多个线程所访问。当前占有资源的线程在任务处理完后,会将拥有的互斥量对象交出,以便其他线程获得并访问资源。
信号量Semophores:
信号量允许多个线程同时使用共享资源。它设置了同时访问共享资源的线程的最大数目。当有线程访问共享资源时,信号量减一,退出时加一,来保存贡献资源线程的最大数目。信号量适用于对套接字程序的线程同步。
事件 Event :
事件通过通知操作的方式来保持多线程的同步,并实现不同进程中的线程同步操作。
四种方式只有最简单的临界区不能跨进程。
临界区,互斥量,信号量和事件。
临界区Critical Section:
保证某一时刻,只有一个线程能访问数据的简便方法。当有一个程序在进入临界区后,其他试图访问这个临界区的线程都会被挂起,直到进入临界区的线程离开。
互斥量 Mutex :
与临界区相似,只有拥有互斥对象的线程才具有访问资源的权限,由于互斥对象只有一个,决定了任何情况下此共享资源都不会被多个线程所访问。当前占有资源的线程在任务处理完后,会将拥有的互斥量对象交出,以便其他线程获得并访问资源。
信号量Semophores:
信号量允许多个线程同时使用共享资源。它设置了同时访问共享资源的线程的最大数目。当有线程访问共享资源时,信号量减一,退出时加一,来保存贡献资源线程的最大数目。信号量适用于对套接字程序的线程同步。
事件 Event :
事件通过通知操作的方式来保持多线程的同步,并实现不同进程中的线程同步操作。
四种方式只有最简单的临界区不能跨进程。
相关文章推荐
- 多线程第七篇:互斥和同步总结
- linux多进程多线程互斥同步例子
- windows 多线程 同步与互斥
- 多线程的同步和互斥
- Linux多线程编程(不限Linux)——本文一个例子展开,介绍Linux下面线程的操作、多线程的同步和互斥。
- 【Linux多线程】同步与互斥的区别
- 关于多线程编程 同步、互斥、读写问题的链接
- GNU/Linux中解决多线程互斥同步问题
- iOS (objective-c) 中的多线程互斥同步问题
- 多线程中的互斥与同步
- iOS 多线程 锁 互斥 同步
- Linux多线程的同步与互斥
- 【Linux多线程】同步与互斥的区别
- java基础——多线程(线程的同步互斥与通信)
- iOS (objective-c) 中的多线程互斥同步问题
- linux多进程多线程互斥同步例子
- (转)多线程编程浅析(3)——多线程的互斥与同步
- 2.使用synchronized关键字实现多线程的同步和互斥(不同线程同时读写同一数据)
- java多线程详解(3)-线程的互斥与同步
- 多线程之互斥、同步方法解析