线程条件变量的使用
来源:互联网 发布:老a淘宝工具箱 编辑:程序博客网 时间:2024/05/18 00:09
1. mutex的用法
#include <stdio.h>#include <pthread.h>pthread_mutex_t lock;int value = 10;void* pt1(void *arg);void* pt2(void *arg);int main() {pthread_t t1, t2;pthread_mutex_init(&lock, NULL);pthread_create(&t1, NULL, pt1, NULL);pthread_create(&t2, NULL, pt2, NULL);pthread_join(t1, NULL);pthread_join(t2, NULL);pthread_mutex_destroy(&lock);return 0;}void* pt1(void *arg) {pthread_mutex_lock(&lock);int i;for(i=0; i<5; i++) {printf("in pt1():, value = %d\n", value++);sleep(1);}pthread_mutex_unlock(&lock);return NULL;}void* pt2(void *arg) {pthread_mutex_lock(&lock);int i;for(i=0; i<5; i++) {printf("in pt2():, value = %d\n", value++);sleep(1);}pthread_mutex_unlock(&lock);return NULL;}
可以看出来加锁之后确实是当线程1完全执行完之后再执行线程2的,线程之间没有交替进行。所以输出的结果肯定要么是pt1()先完全执行完,或者再pt2()。两个函数的循环操作就看成了是一个原子的操作(因为两个函数使用了相同的锁),为了在类似的原子操作中提供更多的控制方法,所以有了条件变量。
pthread_cond_wait()的作用就是能解开当前的锁,并阻塞在这条语句中,所以一般pthread_cond_wait()都是夹在加锁和解锁函数中。
void* pt1(void *arg) {pthread_mutex_lock(&lock);int i;for(i=0; i<5; i++) {if (i == 3) pthread_cond_wait(&flag, &lock);printf("in pt1():, value = %d\n", value++);sleep(1);}pthread_mutex_unlock(&lock);return NULL;}void* pt2(void *arg) {sleep(1);pthread_mutex_lock(&lock);int i;for(i=0; i<5; i++) {printf("in pt2():, value = %d\n", value++);sleep(1);}pthread_mutex_unlock(&lock);pthread_cond_signal(&flag);return NULL;}
对pt1和pt2分别加了条件变量,pt2第一行加了sleep(1)保证pt1优先执行
输出结果:
pt1执行了3次后就可以转到pt2了,执行完pt2,再回头处理pt1,这样就达到了跳出pt1循环5次的原子操作。
0 0
- 线程条件变量的使用
- 线程条件变量使用
- 线程中的条件变量的使用
- 线程同步、条件变量、互斥锁的使用
- 线程同步、条件变量、互斥锁的使用
- 线程的同步--条件变量
- 线程的条件变量实例
- 线程同步:条件变量的使用细节分析
- 线程间同步,条件变量,互斥锁的使用
- 线程同步:条件变量的使用细节分析
- 线程同步:条件变量的使用细节分析
- 线程同步:条件变量的使用细节分析
- 线程同步:条件变量的使用细节分析
- linux线程同步:互斥量和条件变量的使用
- 线程同步机制条件变量的使用与思考
- 条件变量的使用
- 条件变量的使用
- linux线程同步 条件变量使用
- 逻辑题
- 实数的认识
- 长投#基础知识
- HDU 5832 A water problem(水~)
- float与double的范围和精度
- 线程条件变量的使用
- 递归神经网络不可思议的有效性
- cocos2d-JS 实现 横竖屏提示效果
- iframe 跨域
- WebService服务端、客户端编码,以及发布、访问
- 树链剖分详解
- SEL (@selector) 简单总结
- 对于ccbi文件的加载使用的理解
- 【计算机视觉】HDR之tone mapping简介