概述
如果线程1对mutex加锁,那么可以在线程2中对这个mutex解锁,不要求一定是同一个线程完成必须同时完成加锁和解锁。
Demo:
#include <stdio.h>
#include <pthread.h>
#include <unistd.h>
#define N 1
//互斥量 就是锁
pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;
void * myThread(void *arg){
int id = *(int *)arg;
int i;
//printf("current thread is :%dn",id);
printf("child thread locked: %dn",id);
//线程操作前要加锁
pthread_mutex_lock(&mutex);
printf("child thread unlocked: %dn",id);
sleep(100);
for(i=0;i<N;i++){
printf("current thread :%d printn",id);
sleep(1);
}
//释放后要解锁
pthread_mutex_unlock(&mutex);
}
int main(){
pthread_t thread[N];
int id[N],i;
pthread_mutex_lock(&mutex);
for(i=0;i<N;i++){
id[i] = i;
/*
创建线程
第一个参数:传入pthread_t 声明的线程地址
第二个参数:传入NULL即可
第三个参数:传入线程入口地址 函数指针
第四个参数:传入给线程的参数 void*类型的
*/
pthread_create(&thread[i], NULL, myThread, &id[i]);
}
printf("wait 10 sec for child thread start upn");
sleep(10);
pthread_mutex_unlock(&mutex);
printf("main thread unlock the lock that child is holdingn");
//当前线程等待所有线程运行完,然后才继续运行,和java的api类似
for(i=0;i<N;i++){
pthread_join(thread[i],NULL);
}
return 0;
}
最后
以上就是高兴电脑为你收集整理的[C][Linux] pthread mutex 加解锁的全部内容,希望文章能够帮你解决[C][Linux] pthread mutex 加解锁所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复