线程条件变量的使用

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
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值