关闭

Linux 多线程编程( POSIX )( 五 )----->条件变量

标签: 多线程linux编程signalthread框架
892人阅读 评论(0) 收藏 举报
分类:


Attebtion:打开相关代码链接


1.   条件变量

 
  条件变量是用来等待而不是用来上锁的。条件变量用来自动阻塞一个线程,直到
   某特殊情况发生为止。通常条件变量和互斥锁同时使用。
   
   条件变量使我们可以睡眠等待某种条件出现。
   条件变量是利用线程间共享的全局变量进行同步的机制,主要包括两个动作:
   >: 一个线程等待"条件变量的条件成立"而挂起;
   >: 另一个线程使"条件成立"(给出条件成立信号)。可能是一个进程的输出是另一
      个的输入呗~
   
    注意:
   条件的检测是在互斥锁的保护下进行的。如果一个条件为假,一个线程自动阻
   塞,并释放等待状态改变的互斥锁。如果另一个线程改变了条件,它发信号给关
   联的条件变量,唤醒一个或多个等待它的线程,重新获得互斥锁,重新评价条
   件。如果两进程共享可读写的内存,条件变量可以被用来实现这两进程间的线程
    同步。
   
   和互斥变量一样,使用条件变量之前要先进行初始化,也有2方法:
   1.静态:pthead_cond_t    condition =PTHREAD_COND_INITIALIZER
   2.动态:pthread_cond_init
   
2.   条件变量初始化函数
   pthread_cond_init
    #include<pthread.h>
    intpthread_cond_init( thread_cond_t * cond, pthread_condattr_t * attr);
    参数:
   cond  条件变量
   attr     条件变量属性
   成功返回0,出错返回错误编号。
   
   注意:如果参数attr为空,那么它将使用缺省的属性来设置所指定的条件变量。
   
3.   条件变量摧毁函数   
    #include<pthread.h>
    intpthread_cond_destroy( pthread_cond_t * cond );
   成功返回0,出错返回错误编号。
   
   注意:摧毁所指定的条件变量,同时将会释放所给它分配的资源。调用该函数的
          进程也并不要求等待在参数所指定的条件变量上。
   
4.   条件变量等待函数
    #include<pthread.h>   
    intpthread_cond_wait(pthread_cond_t *cond,pthread_mutex_t*mutex);
   
    intpthread_cond_timedwait(pthread_cond_t *cond,pthread_mutex_t *
    mytex,conststruct timespec *abstime);
   
    参数:
       cond条件变量
       mutex互斥锁
   
    注意区别:
             函数pthread_cond_timedwait函数类型与函数pthread_cond_wait,区别在
             于,如果达到或是超过所引用的参数*abstime,它将结束并返回错误
             ETIME.
   
    typedefstruct timespec
    {
      time_t    tv_sec;   //!> 秒
      long    tv_nsex;   //!> 毫秒
   }timespec_t;
   
   也就是说当时间超过预设值后就返回错误!
   
5.   条件变量通知函数
    #include<pthread.h>
    intpthread_cond_signal( pthread_cond_t * cond );
    intpthread_cond_broadcast( pthread_cond_t * cond );
   参数:cond       条件变量
   成功返回0,出错返回错误编号。
   
   pthread_cond_signal:只唤醒一个线程
   pthread_cond_broadcast:唤醒所有线程
   
    注意:
   >: 当调用pthread_cond_signal时一个在相同条件变量上阻塞的线程将被解锁。
   >: 如果同时有多个线程阻塞,则由调度策略确定接收通知的线程。
   >:如果调用pthread_cond_broadcast,则将通知阻塞在这个条件变量上的所有线
      程。一旦被唤醒,线程仍然会要求互斥锁。
   >: 如果当前没有线程等待通知,则上面两种调用实际上成为一个空操作。如果参
      数*cond指向非法地址,则返回值EINVAL。
   
   >::::: 我们有code可以知道,其实本质还是等待,只不过是为了某个条件而等待、、、
   
5.   条件变量属性讨论   
   其实和我们之前说的“互斥量的属性”基本框架是一样的。。。
   下面就是讨论函数。。。

6.   初始化属性函数
    #include<pthread.h>
    intpthread_condattr_init( pthread_condattr * attr);   
   若成功返回0,若失败返回错误编号。
   初始化的是默认的属性、、、、、
   
7.   销毁函数
    #include<pthread.h>   
    intpthread_condattr_destroy( pthread_condattr_t * attr );
   若成功返回0,若失败返回错误编号。
   
8.   查看属性函数
    #include<pthread.h>
    intpthread_condattr_getshared( const pthread_condattr_t * attr, int *shared );
   若成功返回0,若失败返回错误编号。
   
9.   修改属性参数
    #include<pthread.h>   
    intpthread_condattr_setshared( const pthread_condattr_t * attr, intshared );
   若成功返回0,若失败返回错误编号。
   
   关于shared的取值:
   PTHREAD_PROCESS_PRIVATE(一个进程内使用)
   PTHREAD_PROCESS_SHARED(进程间共享).

2
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:589740次
    • 积分:6865
    • 等级:
    • 排名:第3830名
    • 原创:182篇
    • 转载:36篇
    • 译文:0篇
    • 评论:82条
    博客专栏