ImageVerifierCode 换一换
格式:DOC , 页数:4 ,大小:33.50KB ,
资源ID:6335645      下载积分:10 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.docduoduo.com/d-6335645.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录   微博登录 

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(互斥锁的使用.doc)为本站会员(jw66tk88)主动上传,道客多多仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知道客多多(发送邮件至docduoduo@163.com或直接QQ联系客服),我们立即给予删除!

互斥锁的使用.doc

1、互斥锁索引:1. 初始化互斥锁 pthread_mutex_init2. 锁定互斥锁 pthread_mutex_lock3. 解锁互斥锁 pthread_mutex_unlock4. 非阻塞的锁定互斥锁 pthread_mutex_trylock5. 释放互斥锁 pthread_mutex_destroy6. 分级锁定_1.初始化互斥锁 pthread_mutex_init#include int pthread_mutex_init(pthread_mutex_t *mp, const pthread_mutexattr_t *mattr);返回值:函数成功返回 0;任何其他返回值都表示错

2、误当输入参数 mattr为空指针时,pthread_mutex_init()函数以默认值初始化由参数 mp指定的互斥锁。当输入参数 mattr指向 一个互斥锁属性对象时,pthread_mutex_init()函数被用来创建一个指定属性的互斥锁,其属性为参数 mattr指向的互斥锁属性对象的属 性。初始化一个互斥锁以后,这个互斥锁处在解锁状态。对于静态定义的互斥锁,可以直接通过宏PTHREAD_MUTEX_INITIALIZER将其初始化为具有缺省属性。如:pthread_mutex_t mp = PTHREAD_MUTEX_INITIALIZER;当其他线程仍然需要使用某个互斥锁时,这个互斥

3、锁不能被重新初始化或释放。否则将会造成程序故障,在释放、初始化一个互斥锁之前,应用程序必须先确认这个互斥锁未被使用。2.锁定互斥锁 pthread_mutex_lock#include int pthread_mutex_lock(pthread_mutex_t *mutex);返回值:函数成功返回 0;任何其他返回值都表示错误锁定 mutex参数指向的互斥锁对象。当这个函数返回时,相应的互斥锁被锁定,调用 pthread_mutex_lock函数的线程成为这个互斥锁 的拥有者。如果这个互斥锁已经被其他线程锁定,那么调用pthread_mutex_lock函数的线程将一直被阻塞,直到获得这个互

4、斥锁。错误检测和死锁处理依赖于互斥锁类型。3.解锁互斥锁 pthread_mutex_unlock#include int pthread_mutex_unlock(pthread_mutex_t *mutex);返回值:函数成功返回 0;任何其他返回值都表示错误解开已锁定了的互斥锁。解开互斥锁的具体操作根据互斥锁类型的不同而不同。如果调用 pthread_mutex_unlock解开一个互斥锁时,有多个线程正被这个互斥锁阻塞,那么系统将根据调度策略决定哪个线程将获得这 个互斥锁(对于 PTHREAD_MUTEX_RECURSIVE类型的互斥锁来说,只有当互斥锁的锁定计数减少为 0时, pth

5、read_mutex_unlock函数才会解开这个互斥锁,调度被这个互斥锁阻塞的线程)。在缺省的调度策略(SCHED_OTHER)下,一般 是按照线程的优先级高低来释放阻塞线程,重新锁定互斥锁。4.非阻塞的锁定互斥锁 pthread_mutex_trylock#include int pthread_mutex_trylock(pthread_mutex_t *mutex);返回值:函数成功返回 0;任何其他返回值都表示错误函数是 pthread_mutex_lock函数的非阻塞版本。如果 mutex参数所指定的互斥锁已经被锁定的话,调用 pthread_mutex_trylock函数不会阻塞

6、当前线程,而是立即返回一个值来描述互斥锁的状况。5.释放互斥锁 pthread_mutex_destroy#include int pthread_mutex_destroy(pthread_mutex_t *mp);返回值:函数成功返回 0;任何其他返回值都表示错误将相应互斥锁还原成未初始化状态,使以后对该互斥锁的访问都无效。注意:存储互斥锁的内存并未被释放。6.分级锁定有时候我们会需要一次访问两个资源。也许当你使用一个资源时发现还需要另外一个资源。当两个线程试图同时占用两个资源,并按不同的次序锁定相应的互斥锁时,有可能会产生死锁。解决这个问题的最好方法是,确保线程锁定多个互斥锁时,按同一个顺序进行锁定。这项技术被叫做分级锁定:为互斥锁指定逻辑序号并按序号安排锁定的次序。也就是说,当你锁定了一个逻辑序号比 n大的互斥锁时,不能再锁定一个逻辑序号为 n的互斥锁。但在有的情况下,你必须不按预定的顺序来锁定互斥锁。为了防止这种情况下出现死锁,可使用 pthread_mutex_trylock()函数。使用这个函数时注意,当线程发现死锁已经不可避免时,它必须先解锁以前占用的互斥锁。

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报