pthread_mutex_lock用法(转)

条件变量   

  条件变量是利用线程间共享的全局变量进行同步的一种机制,主要包括两个动作:一个线程等待"条件变量的条件成立"而挂起;另一个线程使"条件成立"(给出条件成立信号)。为了防止竞争,条件变量的使用总是和一个互斥锁结合在一起。  

条件变量是利用线程间共享的全局变量进行同步的一种机制,主要包括两个动作:
1)一个线程等待"条件变量的条件成立"而挂起;
2)另一个线程使"条件成立"(给出条件成立信号)。
为了防止竞争,条件变量的使用总是和一个互斥锁结合在一起。

1.主要涉及到下面的函数:
int pthread_cond_init(pthread_cond_t *cond, pthread_condattr_t *cond_attr) ---动态创建条件变量

pthread_mutex_lock ---互斥锁上锁

pthread_mutex_unlock ----互斥锁解锁

pthread_cond_wait() / pthread_cond_timedwait -----等待条件变量,挂起线程,区别是后者,会有timeout时间,如 果到了timeout,线程自动解除阻塞,这个时间和 time()系统调用相同意义的。以1970年时间算起。

pthread_cond_signal ----激活等待列表中的线程,

pthread_cond_broadcast() -------激活所有等待线程列表中最先入队的线程

注意:1)上面这几个函数都是原子操作,可以为理解为一条指令,不会被其他程序打断
           2)上面这个几个函数,必须配合使用。

           3)pthread_cond_wait,先会解除当前线程的互斥锁,然后挂线线程,等待条件变量满足条件。一旦条件变                   量满足条件,则会给线程上锁,继续执行pthread_cond_wait

 

2. 代码实例
编译:gcc thread_test.c -o thread_test -lpthread
------必须加上-lpthread,不然会报错,找不到线程的相关函数,gcc自身没有连接线程

#include<pthread.h>
#include<unistd.h>
#include<stdio.h>
#include<stdlib.h>
 
pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;/*初始化互斥锁*/
pthread_cond_t  cond = PTHREAD_COND_INITIALIZER;//init cond
 
void *thread1(void*);
void *thread2(void*);
 
int i = 1; //global
 
int main(void){
    pthread_t t_a;
    pthread_t t_b;//two thread
 
    pthread_create(&t_a,NULL,thread2,(void*)NULL);
    pthread_create(&t_b,NULL,thread1,(void*)NULL);//Create thread
    
    printf("t_a:0x%x, t_b:0x%x:", t_a, t_b);
    pthread_join(t_b,NULL);//wait a_b thread end
    pthread_mutex_destroy(&mutex);
    pthread_cond_destroy(&cond);
   exit(0);
}
 
void *thread1(void *junk){
    for(i = 1;i<= 9; i++){
        pthread_mutex_lock(&mutex); //互斥锁
        printf("call thread1 \n");
        if(i%3 == 0)
        	{
            pthread_cond_signal(&cond); //send sianal to t_b
            printf("thread1:******i=%d\n", i);
        	}
        else
            printf("thread1: %d\n",i);
        pthread_mutex_unlock(&mutex);
 
		printf("thread1: sleep i=%d\n", i);
        sleep(1);
		printf("thread1: sleep i=%d******end\n", i);
    }
}
 
void *thread2(void*junk){
    while(i < 9)
    {
        pthread_mutex_lock(&mutex);
        printf("call thread2 \n");
        if(i%3 != 0)
            pthread_cond_wait(&cond,&mutex); //wait
         printf("thread2: %d\n",i);
        pthread_mutex_unlock(&mutex);
 
		printf("thread2: sleep i=%d\n", i);
        sleep(1);
		printf("thread2: sleep i=%d******end\n", i);		
    }
}                                    

运行结果

[tandd@localhost test]$ ./thread_test
call thread2 
t_a:0xb76f6b70, t_b:0xb6cf5b70:call thread1 
thread1: 1
thread1: sleep i=1
thread1: sleep i=1******end
call thread1 
thread1: 2
thread1: sleep i=2
thread1: sleep i=2******end
call thread1 
thread1:******i=3
thread1: sleep i=3
thread2: 3
thread2: sleep i=3
thread1: sleep i=3******end
call thread1 
thread1: 4
thread1: sleep i=4
thread2: sleep i=4******end
call thread2 
thread1: sleep i=4******end
call thread1 
thread1: 5
thread1: sleep i=5
thread1: sleep i=5******end
call thread1 
thread1:******i=6
thread1: sleep i=6
thread2: 6
thread2: sleep i=6
thread1: sleep i=6******end
call thread1 
thread1: 7
thread1: sleep i=7
thread2: sleep i=7******end
call thread2 
thread1: sleep i=7******end
call thread1 
thread1: 8
thread1: sleep i=8
thread1: sleep i=8******end
call thread1 
thread1:******i=9
thread1: sleep i=9
thread2: 9
thread2: sleep i=9
thread1: sleep i=9******end
[tandd@localhost test]$ 

转载至https://blog.csdn.net/u012109245/article/details/38662371

  • 17
    点赞
  • 118
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
`pthread_mutex_trylock` 函数用于尝试对一个互斥锁进行加锁,如果该锁当前没有被其他线程占用,则加锁成功,返回0;否则,加锁失败,返回EBUSY。其函数原型如下: ```c #include <pthread.h> int pthread_mutex_trylock(pthread_mutex_t *mutex); ``` 其中,`mutex` 参数是指向互斥锁变量的指针。 使用 `pthread_mutex_trylock` 时需要注意以下几点: 1. 确保互斥锁已经被初始化,否则加锁行为是未定义的。 2. 如果一个线程已经拥有了该互斥锁,再次尝试对该锁进行加锁会导致死锁。 3. 在加锁成功后,必须在合适的时候调用 `pthread_mutex_unlock` 函数对该锁进行解锁,否则会导致其他线程永远无法对该锁进行加锁。 下面是一个简单的示例程序: ```c #include <stdio.h> #include <pthread.h> pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER; void* thread_func(void* arg) { int ret = pthread_mutex_trylock(&mutex); if (ret == 0) { printf("Thread %ld got the lock.\n", (long)arg); pthread_mutex_unlock(&mutex); } else { printf("Thread %ld failed to get the lock.\n", (long)arg); } return NULL; } int main() { pthread_t thread1, thread2; pthread_create(&thread1, NULL, thread_func, (void*)1); pthread_create(&thread2, NULL, thread_func, (void*)2); pthread_join(thread1, NULL); pthread_join(thread2, NULL); return 0; } ``` 该程序创建了两个线程分别尝试对互斥锁进行加锁。其中,一个线程能够成功获取到锁,另一个线程则失败。运行结果类似如下: ``` Thread 1 got the lock. Thread 2 failed to get the lock. ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值