网站大量收购独家精品文档,联系QQ:2885784924

Linux下线程的同步和互斥.ppt

  1. 1、本文档共15页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Linux下线程的同步和互斥 mutex Mutex:互斥设备(MUTual Exclusion device) 快速(fast) mutex 递归(recursive) mutex:获得锁的线程可以多次加锁 错误检测(error checking)mutex:锁定时返回错误 mutex相关函数 int pthread_mutex_init(pthread_mutex_t *mutex, const pthread_mutexattr_t *mutexattr); int pthread_mutex_lock(pthread_mutex_t *mutex); int pthread_mutex_trylock(pthread_mutex_t *mutex); int pthread_mutex_unlock(pthread_mutex_t *mutex); int pthread_mutex_destroy(pthread_mutex_t *mutex); 锁定互斥锁 int pthread_mutex_lock(pthread_mutex_t *mutex); 在成功完成之后会返回零。其他任何返回值都表示出现了错误。 当返回时,该互斥锁已被锁定。调用线程是该互斥锁的属主。 互斥锁类型为快速锁:如果该互斥锁已被另一个线程锁定和拥有,则调用线程将阻塞,直到该互斥锁变为可用为止。 互斥锁类型为错误锁:则会提供错误检查。如果某个线程尝试重新锁定的互斥锁已经由该线程锁定,则将返回错误。如果某个线程尝试解除锁定的互斥锁不是由该线程锁定或者未锁定,则将返回错误。 互斥锁类型为 递归锁:则该互斥锁会保留锁定计数这一概念。线程首次成功获取互斥锁时,锁定计数会设置为 1。线程每重新锁定该互斥锁一次,锁定计数就增加 1。线程每解除锁定该互斥锁一次,锁定计数就减小 1。 锁定计数达到 0 时,该互斥锁即可供其他线程获取。如果某个线程尝试解除锁定的互斥锁不是由该线程锁定或者未锁定,则将返回错误。 解除锁定互斥锁 int pthread_mutex_unlock(pthread_mutex_t *mutex); 释放 引用的互斥锁对象。互斥锁的释放方式取决于互斥锁的类型属性。 在成功完成之后会返回零。其他任何返回值都表示出现了错误 。 使用MUTEX的简单代码 pthread_mutex_t mylock; mylock= PTHREAD_MUTEX_INITIALIZER; pthread_mutex_lock(mylock); Do something…. pthread_mutex_unlock(mylock); …. pthread_mutex_destroy(mylock); Mutex例子 #include stdio.h #include stdlib.h #include pthread.h #include errno.h #define THREAD_NUMBER 10 static pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER; int sum =0; void* inc(void *arg) { int i =(*(int *)arg); pthread_mutex_lock(mutex); sum = sum +i; pthread_mutex_unlock(mutex); return NULL; } Mutex例子(续) int main(int argc, char *argv[]) { pthread_t pt[THREAD_NUMBER]; int i; int arg[THREAD_NUMBER]; for(i=0; iTHREAD_NUMBER; i++) { arg[i]=i; if(pthread_create(pt[i], NULL, inc, (void *)arg[i])!=0) { printf(pthread_create error\n); exit(1); } } Mutex例子(续) for(i=0; iTHREAD_NUMBER; i++) if(pthread_join(pt[i],NULL)!=0){ printf(pthread_join error\n); exit(1); } printf(sum is %d\n,sum)

文档评论(0)

qingfengxulai + 关注
实名认证
内容提供者

文档来源于网络

1亿VIP精品文档

相关文档