




免费预览已结束,剩余1页可下载查看
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
近期在学习linux下的线程控制, 对于线程同步中的互斥锁和条件变量有些问题,不过在参考了一些书目,还有和同学讨论后也是有了自己的一些认识和见解,现在分享下。先看看互斥锁APIpthread_mutex_lock(pthread_mutex_t *mutex; 用此函数加锁时,如果mutex已经被锁住,当前尝试加锁的线程就会阻塞,直到互斥锁被其他线程释放。当此函数返回时,说明互斥锁已经被当前线程成功加锁.pthread_mutex_trylock(pthread_mutex_t *mutex); 用此函数加锁时,如果mutex已经卑琐主,当前尝试加锁的线程不会阻塞,而是立即返回,返回的错误码为EBUSY,而不是阻塞等待。pthread_mutex_unlock(pthread_mutex_t *mutex);注意使用锁之前要记得初始化。互斥锁的初始化有两种初始化方式:1.对于静态分配的互斥锁一半用宏赋值的方式初始化eg: static pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;2.对于动态分配的互斥锁(如调用malloc)或分配在共享内存中,则必须调用pthread_mutex_init(pthread_mutex *mutex, pthread_mutexattr_t *mutexattr)函数来进行初始化。有时候省略了初始化操作代码,因为它所在的实现把初始化常值定义为0(而且静态分配的变量被自动初始化为0),不过省略初始操作是不正确的!互斥锁的作用:互斥锁是用来保护临界区资源,一般是一些可供线程间使用的全局变量,来达到线程同步的目的,即保证任何时刻只有一个线程或进程在执行其中的代码.也许有人会问什么是同步?我以开始也不知道后来在百度找到了答案。线程同步:发生在多个线程共享相同内存的时候,这事要保证每个线程在每个时刻看到的共享数据是一致的,如果每个线程使用的变量都是其他线程不会使用的read&write或者变量是只读的,就不存在一致性的问题,但是如果两个或两个以上的线程可以read/write同一个变量时,就需要对线程进行同步,以确保他们在访问该变量的时不会得到无效的值,同时也可以唯一地修改变量并使它生效。通俗点说:一个父亲给三个盲人儿子分蛋糕, 父亲不吃,只是分配。按照年龄分配,小儿子先吃了三分之一,然后给父亲,父亲接着将蛋糕给二儿子并告诉二儿子蛋糕剩下三分之二,二儿子又吃了三分之一后还给父亲,接着父亲告诉大儿子剩下三分之一,然后大儿子吃完了。最后父亲告诉三个儿子蛋糕都被你们吃完了。让儿子们都知道蛋糕还剩多少,这就叫做同步。此处父亲就像CUP,蛋糕就像三个线程的共享变量,三个儿子就是三个线程. 按照年龄分配就像是线程调度的按优先级分配的策略。互斥锁的存在正是用来保护这种共享变量的,一般的加锁轮廓:1.pthread_mutex_lock()2./*数据(变量)*/3.pthread_mutex_unlock()1为接下来的操作加锁,实际上是为数据(data)加锁,这样保证在执行第3句pthread_mutex_unlock()前,其他的线程不能访问第二句中的数据,只能阻塞等待解锁后来访问该数据。如果有多个线程阻塞在等待同一个互斥锁上,那么当该互斥锁解锁,哪一个线程会开始运行呢?答:1003.1b-1993标准增加的特性之一是提供一个优先级调度选项。一下为概括,不同的线程可被赋予不同的优先级,同步函数(互斥锁,读写锁,信号量)将唤醒优先级最高的被阻塞线程。关于互斥锁的编程技巧 将共享数据和他们的同步变量(互斥锁,条件变量或信号量)收集到一个结构体中。但是,对于动态分配的,如链表,可以将链表的头以及链表的同步变量存放到一个结构体中,但是其他共享数据(该链表的其他部分)却不在该结构中,因此这种方式通常是不完善的。Example: strcut pthread_mutex_tmutex; intbuffMAXITEMS; int nput; int nval; shared = PTHREAD_MUTEX_INITIALIZER 条件变量APIpthread_cond_wait(pthread_cond_t *cond, pthread_mutex_t *mutex);使用时需要注意:条件变量的使用是与互斥锁共通使用的。参数cond使用前 需要用 pthread_cond_init(pthread_cond_t *cond, pthread_condattr_t *cond_attr);初始化!参数mutex为已经初始化后,并且是已经上锁的状态!pthread_cond_timedwait(pthread_cond_t *cond, pthread_mutex, const struct timespec *abstime);用此函数时,函数将阻塞直到条件变量或得信号或者经过由abstime指定的时间,也就是说,如果在给定时刻前条件没有满足,则返回ETIMEOUT,结束等待。 abstime = 0 表示1997年1月1日00:00:00 GMTeg:1 for ( ; ; )2 3 pthread_mutex_lock (&mutex);4 if (condition)5 pthread_cond_wait(&cond, &mutex);6 /*do something*/7 pthread_mutex_unlock(&mutex);8第3行为下面的操作加锁,第4行是判断是否要调用条件变量;当满足判断条件执行wait时候,wait函数先释放mutex对应的互斥锁,然后阻塞第6行之后的语句执行。即其他线程在wait函数等待得时候可以调用mutex,并且对例子代码中互斥锁要保护的数据进行修改。当后面有线程满足某些设定的条件执行了pthread_cond_singal(pthread cond_t *cond);或者是执行pthread_cond_broadcast(pthread_cond_t *cond);此时wait函数所在的线程做的第一件事情就是为它接下来的操作加上mutex,这时wait才返回,线程醒来.pthread_cond_signal(pthread_cond_t *cond);激活一个等待条件成立的线程,存在多个等
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 低血压基础试题及答案
- 会计基础考试题库及答案
- 会计从业资格试题及答案
- 什么是招聘试题及答案
- 人民日报政治试题及答案
- 2025年农产品追溯体系在构建农产品质量安全信用体系中的应用报告
- 正切数学题目及答案
- 运输安全试题及答案解析
- 2025年农产品质量安全追溯体系与农业供应链金融创新研究报告
- 疫情期间中考题库及答案
- 《公路工程预算定额》(JTGT3832-2018)
- 基本药物政策培训
- 古镇旅游活动策划方案
- 清远市突发事件总体应急预案
- 通风与防排烟系统的施工方案
- 沪教版英语小学四年级上学期试卷与参考答案(2024-2025学年)
- 人工智能训练师理论知识考核要素细目表二级
- 2024年人教版一年级数学(下册)期末试卷及答案(各版本)
- 《卒中患者吞咽障碍护理规范》
- DL∕T 698.45-2017 电能信息采集与管理系统 第4-5部分:通信协议-面向对象的数据交换协议
- GB/T 44189-2024政务服务便民热线运行指南
评论
0/150
提交评论