条件变量 pthread_cond_wait 函数的解锁和等待为原子操作
2014-05-22 11:48
302 查看
看网上的示例代码,总是看不懂,总是觉得哪里不对,直到看到《POSIX多线程设计》关于条件变量的讲解后,才明白示例是对的
POSIX标准保证:pthread_cond_wait( pthread_cond_t*cond ,pthread_mutex_t* mtx )这个函数参数mtx的解锁和等待参数cond的动作是原子性的
也就是说,pthread_cond_wait在解锁mtx后,等待cond前,不会mtx不会被再次锁住。
在这个保证下,网上的示例(如下),就可以解释通了:
POSIX标准保证:pthread_cond_wait( pthread_cond_t*cond ,pthread_mutex_t* mtx )这个函数参数mtx的解锁和等待参数cond的动作是原子性的
也就是说,pthread_cond_wait在解锁mtx后,等待cond前,不会mtx不会被再次锁住。
在这个保证下,网上的示例(如下),就可以解释通了:
线程1 pthread_mutex_lock( mtx ); while( 条件判断) {//这里使用while,是因为pthread_cond_wait等待时,可能被意外唤醒(不是pthread_cond_signal也不是pthread_cond_broadcast) //而且,意外唤醒很容易复现。例如在Mac本上用Xcode打断点或删除断点都可以唤醒pthread_cond_wait等待 pthread_cond_wait( cond , mtx ); // (unlock -> block 这两步原子操作) -> wake -> lock } pthread_mutex_unlock( mtx ); 线程2 pthread_mutex_lock( mtx ); pthread_cond_signal( cond ); pthread_mutex_unlock( mtx );
相关文章推荐
- 互斥量、条件变量与pthread_cond_wait()函数的使用
- 互斥量、条件变量与pthread_cond_wait()函数的使用
- 互斥量、条件变量与pthread_cond_wait()函数的使用,详解
- 互斥量、条件变量与pthread_cond_wait()函数的使用,详解(二)
- <转载>条件变量(互斥量)与pthread_cond_wait函数详解
- 互斥量、条件变量与pthread_cond_wait()函数的使用,详解
- 互斥量、条件变量与pthread_cond_wait()函数的使用,详解
- 互斥量、条件变量与pthread_cond_wait()函数的使用,详解
- 互斥量、条件变量与pthread_cond_wait()函数的使用,详解
- 条件变量(互斥量)与pthread_cond_wait函数详解
- 互斥量、条件变量与pthread_cond_wait()函数的使用,详解(一)
- SB了,pthread_cond_wait(),在等待的时候会解锁(阻塞之后,解锁mutex给别的线程),唤醒后加锁,
- 互斥量、条件变量与pthread_cond_wait()函数的使用,详解
- pthread_cond_wait() 函数的使用
- pthread_cond_wait() 函数
- POSIX多线程中的pthread_cond_wait() 函数
- pthread_cond_wait()函数的理解
- 条件变量 pthread_cond_wait () 之解释~
- pthread_cond_wait()函数的理解和pthread_cond_signal函数
- 对pthread_cond_wait()函数的理解