[C][Linux] pthread mutex 加解锁
原创
©著作权归作者所有:来自51CTO博客作者obentul的原创作品,请联系作者获取转载授权,否则将追究法律责任
如果线程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 :%d\n",id);
printf("child thread locked: %d\n",id);
//线程操作前要加锁
pthread_mutex_lock(&mutex);
printf("child thread unlocked: %d\n",id);
sleep(100);
for(i=0;i<N;i++){
printf("current thread :%d print\n",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 up\n");
sleep(10);
pthread_mutex_unlock(&mutex);
printf("main thread unlock the lock that child is holding\n");
//当前线程等待所有线程运行完,然后才继续运行,和java的api类似
for(i=0;i<N;i++){
pthread_join(thread[i],NULL);
}
return 0;
}