Linux-条件变量

本文深入探讨了Linux条件变量的概念,作为线程同步的一种机制,它与互斥锁配合使用,允许线程等待特定条件满足。文章通过生产者-消费者模型展示了条件变量的实际应用,并提供了一段使用链表实现的代码示例。在编译涉及pthread的代码时,需要注意链接静态库`-lpthread`。
摘要由CSDN通过智能技术生成

1.条件变量
条件变量描述临界资源内的状态。
条件变量是线程中的东西,就是等待某一条件的发生,和信号一样。
条件变量使我们可以睡眠等待某种条件出现。
条件变量是利用线程间共享的全局变量进行同步的一种机制,主要包括两个动作:一个线程等待”条件变量的条件成立”而挂起;另一个线程使”条件成立”(给出条件成立信号)。为了防止竞争,条件变量的使用总是和一个互斥锁结合在一起
返回值:成功返回0,失败返回错误号。
和Mutex的初始化和销毁类似,pthread_cond_init函数初始化⼀个Condition Variable,attr参数 为NULL则表⽰缺省属性,pthread_cond_destroy函数销毁⼀个Condition Variable。如果ConditionVariable是静态分配的,也可以⽤宏定义PTHEAD_COND_INITIALIZER初始化,相当于 ⽤pthread_cond_init函数初始化并且attr参数为NULL。 Condition Variable的操作可以⽤下列函数:
可见,⼀个Condition Variable总是和⼀个Mutex搭配使⽤的。 ⼀个线程可以调⽤pthread_cond_wait在⼀个Condition Variable上阻塞等待,这个函数做以下三步操作:
1. 释放Mutex
2. 阻塞等待
3. 当被唤醒时,重新获得Mutex并返回
pthread_cond_timedwait函数还有⼀个额外的参数可以设定等待超时,如果到达了abstime所指定的 时刻仍然没有别的线程来唤醒当前线程,就返回ETIMEDOUT。⼀个线程可以调⽤pthread_cond_signal唤醒在某个Condition Variable上等待的另⼀个线程,也可以调⽤pthread_cond_broadcast唤醒在这个Condition Variable上等待的所有线程。
2.生产者和消费者模型
3种关系:生产者-生产者:互斥关系;消费者-消费者:互斥;生产者-消费者:互斥和同步
2种角色:生产者,消费者;
1个交易场所
为了方便记忆,简称321原则
3.代码实现:
//采用链表实现

#include<stdio.h>
#include<pthread.h>
#include<stdlib.h>
typedef struct _node{
    int data;
    struct _node *next;
}node_t,*node_p,**node_pp;

node_p head=NULL;
pthread_mutex_t lock=PTHREAD_MUTEX_INITIALIZER;
pthread_cond_t cond=PTHREAD_COND_INITIALIZER;

static no
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值