当前位置: 首页 > news >正文

linux多线程之条件变量

目录

条件变量基本原理

初始化条件变量:pthread_cond_init

等待条件变量 :pthread_cond_wait

唤醒所有等待线程:pthread_cond_broadcast

销毁条件变量:pthread_cond_destroy

示例代码


条件变量基本原理

        条件变量(Condition Variable)是多线程编程中用于线程同步的一种机制,它允许线程在某个条件满足时被唤醒。
        条件变量通常与互斥锁配合使用。线程在检查某个条件是否满足之前,先获取互斥锁以保护共享资源。如果条件不满足,线程会释放互斥锁并在条件变量上等待。当其他线程修改了共享资源使得条件满足时,它会通知在该条件变量上等待的线程。等待的线程被唤醒后,会重新获取互斥锁,然后检查条件是否真的满足(因为可能存在虚假唤醒,即线程被唤醒但条件实际上并未满足)。

初始化条件变量:pthread_cond_init

  • 函数原型
int pthread_cond_init(pthread_cond_t *cond, const pthread_condattr_t *attr);
  • 功能:初始化一个条件变量。
  • 参数
    • cond:指向要初始化的条件变量的指针。
    • attr:用于指定条件变量的属性,通常设为 NULL 使用默认属性。
  • 返回值:成功时返回 0,失败时返回非零错误码。

等待条件变量 :pthread_cond_wait

  • 函数原型
int pthread_cond_wait(pthread_cond_t *cond, pthread_mutex_t *mutex);
  • 功能:使调用线程在条件变量 cond 上等待。调用该函数前,线程必须已经获取了互斥锁 mutex。函数会自动释放互斥锁,并将线程置于等待状态,直到条件变量被其他线程通过 pthread_cond_signal 或 pthread_cond_broadcast 唤醒。唤醒后,线程会重新获取互斥锁。
  • 参数
    • cond:指向要等待的条件变量的指针。
    • mutex:指向与条件变量关联的互斥锁的指针。
  • 返回值:成功时返回 0,失败时返回非零错误码。

唤醒一个等待线程:pthread_cond_signal

  • 函数原型
int pthread_cond_signal(pthread_cond_t *cond);
  • 功能:唤醒在条件变量 cond 上等待的一个线程。如果有多个线程在等待,具体唤醒哪个线程是由系统决定的。
  • 参数cond:指向要操作的条件变量的指针。
  • 返回值:成功时返回 0,失败时返回非零错误码。

唤醒所有等待线程:pthread_cond_broadcast

  • 函数原型
int pthread_cond_broadcast(pthread_cond_t *cond);
  • 在条件变量 cond 上等待的所有线程。
  • 参数cond:指向要操作的条件变量的指针。
  • 返回值:成功时返回 0,失败时返回非零错误码。

销毁条件变量:pthread_cond_destroy

  • 函数原型
int pthread_cond_destroy(pthread_cond_t *cond);
  • 功能:销毁一个已初始化的条件变量,释放相关资源。在销毁条件变量之前,应确保没有线程在该条件变量上等待。
  • 参数cond:指向要销毁的条件变量的指针。
  • 返回值:成功时返回 0,失败时返回非零错误码。

示例代码

#include <stdio.h>
#include <stdlib.h>
#include <pthread.h>pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;
pthread_cond_t cond = PTHREAD_COND_INITIALIZER;
int ready = 0;void* waiter(void* arg) {pthread_mutex_lock(&mutex);while (!ready) {printf("Waiting for condition...\n");pthread_cond_wait(&cond, &mutex);}printf("Condition met. Continuing...\n");pthread_mutex_unlock(&mutex);return NULL;
}void* signaler(void* arg) {pthread_mutex_lock(&mutex);ready = 1;printf("Setting condition...\n");pthread_cond_signal(&cond);pthread_mutex_unlock(&mutex);return NULL;
}int main() {pthread_t thread1, thread2;pthread_create(&thread1, NULL, waiter, NULL);pthread_create(&thread2, NULL, signaler, NULL);pthread_join(thread1, NULL);pthread_join(thread2, NULL);pthread_mutex_destroy(&mutex);pthread_cond_destroy(&cond);return 0;
}

代码说明:

  • waiter 线程获取互斥锁后,检查 ready 条件。如果 ready 为 0,它会调用 pthread_cond_wait 等待条件变量,并释放互斥锁。
  • signaler 线程获取互斥锁,设置 ready 为 1,然后调用 pthread_cond_signal 唤醒 waiter 线程,最后释放互斥锁。
  • waiter 线程被唤醒后,重新获取互斥锁,检查 ready 条件,发现条件满足后继续执行。最后,主线程等待两个线程完成,并销毁互斥锁和条件变量。

相关文章:

  • 学习昇腾开发的第三天--将服务器连接网络
  • Android 与 ESP-01 WIFI模块通信
  • HTTP协议简易入门
  • Vue3相关知识3
  • JS当中怎么定义一个类
  • Linux信号机制:进程异步通信的秘密
  • Kafka 可靠性保障:消息确认与事务机制(一)
  • XR-RokidAR-UXR3.0-Draggable 脚本解析
  • HTML的最基础入门知识,从零开始逐步讲解,适合为后续爬虫技术打基础:
  • 苏州SAP代理商:哲讯科技助力企业数字化转型
  • [python] 堆
  • 贝塞尔曲线的公式推导贝塞尔曲线的公式推导,和 SVG 中 Path 的贝塞尔曲线指令的理解记忆
  • 体验AI智能投资!AI Hedge Fund了解一下
  • Langflow 构建多代理和 RAG 应用的可视化框架
  • STM32103CBT6显示ST7789通过SPI方式显示柬埔寨文
  • 【Dify系列】【Dify 核心功能】【应用类型】【二】【文本生成】
  • 解决虚拟环境中文绘图显示问题
  • RFC4291-IPv6地址架构
  • 计算机求职提前批/求职什么时候投递合适
  • 从0开始学习R语言--Day24--稀疏建模
  • 疫情防控最新政策要求/百度站长工具seo查询
  • b站视频可以离线观看吗/迅速上排名网站优化
  • 做网站前端设计需要哪些证书/新媒体口碑营销案例
  • 一个网站的建立需要什么/在线数据分析工具
  • c2b网站开发/北京优化seo排名
  • 网站建设如何记账/成都关键词优化报价