1 #include<stdio.h> 2 #include<string.h> 3 #include<pthread.h> 4 #include<stdlib.h> 5 #include<unistd.h> 6 7 pthread_mutex_t mutex; //定义一把互斥锁 ,可以想象为 int mutex=1 8 void *tfn(void *arg){ 9 srand(time(NULL)); 10 while(1){ 11 pthread_mutex_lock(&mutex); //加锁 ,想象为 mutex-- 12 printf("hello "); 13 sleep(rand()%3); 14 printf("world\n"); 15 pthread_mutex_unlock(&mutex); //解锁,想象为 mutex++ 16 sleep(rand()%3); 17 } 18 return NULL; 19 } 20 21 int main(void){ 22 pthread_t tid; 23 srand(time(NULL)); 24 25 int ret = pthread_mutex_init(&mutex,NULL); //初始化互斥锁 26 27 pthread_create(&tid,NULL,tfn,NULL); 28 while(1){ 29 pthread_mutex_lock(&mutex); //加锁 30 printf("HELLO "); 31 sleep(rand()%3); 32 printf("WORLD\n"); 33 pthread_mutex_unlock(&mutex);//解锁 34 sleep(rand()%3); 35 36 } 37 pthread_join(tid,NULL); 38 return 0; 39 }
这里解释一下为什么Line15,33需要先解锁再sleep。不然的话其实就是不给另一个线程cpu调度的时间,直接执行while循环,会出现一直输出全部大写或者全部小写的情况,这不是我们期待的。我们期待的是大小写交替。
读写锁:
与互斥量类似,但读写锁允许更高的并行性,其特性为:写独占,读共享。
锁只有一把。以读方式给数据加锁一一读锁,
以写方式给数据加锁一一写锁
读共享,写独占。
写锁优先级高。
相较于互斥量而言,当读线程多的时候,提高访问效率。
条件变量: