线程访问控制

为什么要进行线程控制呢?就如同我和媳妇买了一辆车,我和我媳妇是共享这辆车的,就类似于线程共享进程的资源。当我们开车去拉萨的时候,我可以开车,她也可以开车,但是两个人不能同时开车,只能一个人来开,要不就会出问题。所以当我需要开车时,我就坐在驾驶的位置上,就相当于给线程上锁了,一旦我坐在驾驶座上,就是我来开车了,别人谁也别想开车,自己媳妇也是不行的。很明显,这是为了安全,是啊,线程控制也是为了安全,省的把数据弄乱了。

要想对线程加锁就要有加锁的方法,系统提供了mutex来对线程进行加锁,当然这是一种互斥锁,互斥锁有两种状态,上锁和解锁。很同意明白,谁上锁谁操作呗,如同我把这个门锁起来了,这如同就是我家,只有我能进去操作。我操作完了,那就没我的事了,我就把锁放开,接着等待下一位上锁人。怎么赶脚有点像找女朋友呢?大笑


互斥锁可以分为快速互斥锁、递归互斥锁和检错互斥锁。快速互斥锁是指调用线程会阻塞直至拥有互斥锁的线程解锁。而检错互斥锁是快速互斥锁的非阻塞版本。递归互斥锁能够成功的返回并且调用线程在互斥上加锁的次数。

下面使用互斥锁对lock_var实现加一的操作。

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <pthread.h>
#include <errno.h>

pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;
int lock_var;
time_t end_time;

void pthread1(void *arg);
void pthread2(void *arg);

int main(int argc, char *argv[])
{
	pthread_t id1,id2;
	pthread_t mon_th_id;
	int ret;

	end_time = time(NULL)+10;
	//互斥锁初始化
	pthread_mutex_init(&mutex,NULL);
	//创建线程
	ret=pthread_create(&id1,NULL,(void *)pthread1, NULL);
	if(ret!=0)
		perror("pthread cread1");
	ret=pthread_create(&id2,NULL,(void *)pthread2, NULL);
	if(ret!=0)
		perror("pthread cread2");
		//等待线程的执行
	pthread_join(id1,NULL);
	pthread_join(id2,NULL);
	exit(0);
}

void pthread1(void *arg)
{
	int i;
	while(time(NULL) < end_time){
	//互斥锁上锁
		if(pthread_mutex_lock(&mutex)!=0){
		perror("pthread_mutex_lock");
		}
		else
			printf("pthread1:pthread1 lock the variable\n");
		for(i=0;i<2;i++){
			sleep(1);
			lock_var++;
		}
		//互斥锁解锁
		if(pthread_mutex_unlock(&mutex)!=0){
			perror("pthread_mutex_unlock");
		}
		else
			printf("pthread1:pthread1 unlock the variable\n");
	sleep(1);
	}
}

void pthread2(void *arg)
{
	int nolock=0;
	int ret;
	while(time(NULL) < end_time){
	//测试互斥锁
		ret=pthread_mutex_trylock(&mutex);
		if(ret==EBUSY)
			printf("pthread2:the variable is locked by pthread1\n");
		else{
			if(ret!=0){
				perror("pthread_mutex_trylock");
				exit(1);
			}
			else
				printf("pthread2:pthread2 got lock.The variable is %d\n",lock_var);
				//互斥锁解锁
			if(pthread_mutex_unlock(&mutex)!=0){
				perror("pthread_mutex_unlock");
			}
			 else
				printf("pthread2:pthread2 unlock the variable\n");
		}
		sleep(3);
	}
}

程序执行的结果:




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值