条件变量是线程同步数据的值,当到达某个值的时候,唤醒某个线程。
pthread_cond_init()初始化
pthread_cond_broadcast()唤醒所有线程
pthread_cond_signal()唤醒某个线程
需要结合互斥锁一起使用,保证同一时间只有一个唤醒操作
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <unistd.h>
#include <assert.h>
#include <pthread.h>
#include <semaphore.h>
#include <sys/wait.h>
pthread_mutex_t mutex;//创建一个锁
pthread_cond_t cond;//创建一个条件变量
char buff[128] = {0};//创建数组存放输入的字符
void *fun(void* arg)
{
char *s = (char*)arg;//存放线程代号
while(1)
{
pthread_mutex_lock(&mutex);//上锁
pthread_cond_wait(&cond,&mutex);//等另一个线程解锁继续获取条件变量
pthread_mutex_unlock(&mutex);//解锁
if(strncmp(buff,"end",3) == 0)//输入end则退出
{
break;
}
printf("%s :%s\n",s,buff);
}
printf("fun %s exit\n",s);
}
int main()
{
pthread_mutex_init(&mutex,NULL);//初始化锁
pthread_cond_init(&cond,NULL);//初始化条件变量
char *str[2] = {"A","B"};//创建线程代号
for(int i = 0;i<2;i++)
{
pthread_create(&id[i],NULL,fun,(void*)str[i]);//创建线程
}
while(1)
{
fgets(buff,128,stdin);//将输入的字符存入buff
if(strncmp(buff,"end",3) == 0)//end则退出主线程
{
pthread_mutex_lock(&mutex);//加锁
pthread_cond_broadcast(&cond);//使所有线程都获得到条件变量值
pthread_mutex_unlock(&mutex);//解锁
break;
}
pthread_mutex_lock(&mutex);//正常情况加锁
pthread_cond_signal(&cond);//某个线程获得该值
pthread_mutex_unlock(&mutex);//解锁
}
for(int i = 0;i<2;i++)
{
pthread_join(id[i],NULL);//获取退出线程的id
}
pthread_mutex_destroy(&mutex);//销毁锁
pthread_cond_destroy(&cond);//销毁条件变量
exit(0);
}