linux互斥锁、条件变量和信号量

linux互斥锁、条件变量和信号量

ID:13441125

大小:38.00 KB

页数:5页

时间:2018-07-22

linux互斥锁、条件变量和信号量_第1页
linux互斥锁、条件变量和信号量_第2页
linux互斥锁、条件变量和信号量_第3页
linux互斥锁、条件变量和信号量_第4页
linux互斥锁、条件变量和信号量_第5页
资源描述:

《linux互斥锁、条件变量和信号量》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、Linux--Linux互斥锁、条件变量和信号量进行多线程编程,最应该注意的就是那些共享的数据,因为无法知道哪个线程会在哪个时候对它进行操作,也无法得知哪个线程会先运行,哪个线程会后运行。所以,要对这些资源进行合理的分配和正确的使用。在Linux下,提供了互斥锁、条件变量和信号量来对共享资源进行保护。一、互斥锁互斥锁,是一种信号量,常用来防止两个进程或线程在同一时刻访问相同的共享资源。需要的头文件:pthread.h互斥锁标识符:pthread_mutex_t(1)互斥锁初始化:函数原型:intpthread_mutex_init(pthr

2、ead_mutex_t*mutex,constpthread_mutexattr_t*mutexattr);函数传入值: mutex:互斥锁。mutexattr:PTHREAD_MUTEX_INITIALIZER创建快速互斥锁。PTHREAD_RECURSIVE_MUTEX_INITIALIZER_NP创建递归互斥锁。PTHREAD_ERRORCHECK_MUTEX_INITIALIZER_NP 创建检错互斥锁。函数返回值:成功:0;出错:-1(2)互斥操作函数intpthread_mutex_lock(pthread_mutex_t*mu

3、tex);//上锁intpthread_mutex_trylock(pthread_mutex_t*mutex);//只有在互斥被锁住的情况下才阻塞intpthread_mutex_unlock(pthread_mutex_t*mutex);//解锁intpthread_mutex_destroy(pthread_mutex_t*mutex);//清除互斥锁函数传入值:mutex:互斥锁。函数返回值:成功:0;出错:-1使用形式:pthread_mutex_tmutex;pthread_mutex_init(&mutex,NULL);/*定

4、义*/...pthread_mutex_lock(&mutex);/*获取互斥锁*/.../*临界资源*/pthread_mutex_unlock(&mutex);/*释放互斥锁*/如果一个线程已经给一个互斥量上锁了,后来在操作的过程中又再次调用了该上锁的操作,那么该线程将会无限阻塞在这个地方,从而导致死锁。这就需要互斥量的属性。互斥量分为下面三种:1、快速型。这种类型也是默认的类型。该线程的行为正如上面所说的。2、递归型。如果遇到我们上面所提到的死锁情况,同一线程循环给互斥量上锁,那么系统将会知道该上锁行为来自同一线程,那么就会同意线程给

5、该互斥量上锁。3、错误检测型。如果该互斥量已经被上锁,那么后续的上锁将会失败而不会阻塞,pthread_mutex_lock()操作将会返回EDEADLK。互斥量的属性类型为pthread_mutexattr_t。声明后调用pthread_mutexattr_init()来创建该互斥量。然后调用pthread_mutexattr_settype来设置属性。格式如下:intpthread_mutexattr_settype(pthread_mutexattr_t*attr,intkind);第一个参数attr,就是前面声明的属性变量;第二个参

6、数kind,就是我们要设置的属性类型。他有下面几个选项:PTHREAD_MUTEX_FAST_NPPTHREAD_MUTEX_RECURSIVE_NPPTHREAD_MUTEX_ERRORCHECK_NP下面给出一个使用属性的简单过程:pthread_mutex_tmutex;pthread_mutexattr_tattr;pthread_mutexattr_init(&attr);pthread_mutexattr_settype(&attr,PTHREAD_MUTEX_RECURSIVE_NP);pthread_mutex_init(&

7、mutex,&attr);pthread_mutex_destroy(&attr);前面我们提到在调用pthread_mutex_lock()的时候,如果此时mutex已经被其他线程上锁,那么该操作将会一直阻塞在这个地方。如果我们此时不想一直阻塞在这个地方,那么可以调用下面函数:pthread_mutex_trylock。如果此时互斥量没有被上锁,那么pthread_mutex_trylock将会返回0,并会对该互斥量上锁。如果互斥量已经被上锁,那么会立刻返回EBUSY。二、条件变量需要的头文件:pthread.h条件变量标识符:pthre

8、ad_cond_t1、互斥锁的存在问题:互斥锁一个明显的缺点是它只有两种状态:锁定和非锁定。设想一种简单情景:多个线程访问同一个共享资源时,并不知道何时应该使用共享资源,如果在临

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。