pthread_cond_wait的一个例子

关于pthread条件变量的一个例子,其中的重点是:

1.pthread_cond_wait会先将调用线程放到等待条件的线程列表上,也就是说线程会阻塞,传递进去的互斥量会解锁;

2.pthread_cond_wait返回时互斥量会再次锁住。

带着这两个要点去看下面的程序,thread1负责打印i的值,thread2负责决定打印的条件。thread1首先锁住lock是为了保证在pthread_cond_signal调用之前首先进入pthread_cond_wait状态。在pthread_cond_wait下线程休眠等待信号并且解锁lock,这样thread2开始运行并且当条件满足时thread2获取lock并调用pthread_cond_signal通知thread1开始打印i。pthread_cond_signal之后解锁lock,这样thread1可以重新锁定lock,并且返回打印出i的值,最后thread1解锁lock开始下一轮循环。

 

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

int i = 0;

pthread_cond_t cond = PTHREAD_COND_INITIALIZER;
pthread_mutex_t lock = PTHREAD_MUTEX_INITIALIZER;

void* thread1(void *arg)
{
    for (;;)
    {
        printf("thread1 loop...\n");
        pthread_mutex_lock(&lock);
        printf("thread1 wait cond...\n");
        pthread_cond_wait(&cond, &lock);
        printf("thread1 work...%d\n", i);
        pthread_mutex_unlock(&lock);
    }

    return (void*)0;
}

void* thread2(void *arg)
{
    sleep(1);

    while (++i < 100)
    {
        printf("thread2 loop...\n");

        if (i % 10 == 0)
        {
            pthread_mutex_lock(&lock);
            pthread_cond_signal(&cond);
            pthread_mutex_unlock(&lock);
            sleep(1);
        }
    }

    printf("thread2 exit\n");
    return (void*)0;
}

int main(void)
{
    pthread_t ntid1;
    pthread_t ntid2;

    pthread_create(&ntid1, NULL, thread1, NULL);
    pthread_create(&ntid2, NULL, thread2, NULL);

    pthread_join(ntid1, NULL);
    pthread_join(ntid2, NULL);

    pthread_mutex_destroy(&lock);
    pthread_cond_destroy(&cond);

    return EXIT_SUCCESS;
}


 

pthread_cond_timedwait函数是POSIX线程库中用于等待条件变量的函数之一。它可以在指定的时间内等待条件变量的状态发生变化。 下面是一个使用pthread_cond_timedwait函数的例子: ```c #include <stdio.h> #include <pthread.h> #include <unistd.h> pthread_mutex_t mutex; pthread_cond_t cond; void* thread_func(void* arg) { pthread_mutex_lock(&mutex); printf("Thread waiting...\n"); struct timespec timeout; clock_gettime(CLOCK_REALTIME, &timeout); timeout.tv_sec += 5; // 设置等待时间为5秒 int result = pthread_cond_timedwait(&cond, &mutex, &timeout); if (result == 0) { printf("Thread woken up!\n"); } else if (result == ETIMEDOUT) { printf("Thread timed out!\n"); } else { printf("Thread wait error!\n"); } pthread_mutex_unlock(&mutex); return NULL; } int main() { pthread_t thread; pthread_mutex_init(&mutex, NULL); pthread_cond_init(&cond, NULL); pthread_create(&thread, NULL, thread_func, NULL); sleep(2); // 等待2秒,确保子线程已经开始等待 pthread_mutex_lock(&mutex); printf("Main thread signaling...\n"); pthread_cond_signal(&cond); pthread_mutex_unlock(&mutex); pthread_join(thread, NULL); pthread_mutex_destroy(&mutex); pthread_cond_destroy(&cond); return 0; } ``` 在这个例子中,我们创建了一个子线程,子线程会在条件变量上等待。主线程等待2秒后,通过调用pthread_cond_signal函数来通知子线程条件变量的状态发生了变化。子线程在等待时间到达或者收到信号时会被唤醒,并打印相应的信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值