使用线程信号量解决线程的同步问题
PV操作--结果计算
程序模型
将线程信号量(I)的初值设为0,t1计算完毕做v(1)操作,t2先做p(1)操作阻塞,等到t1做v(1)操作完毕,t2从阻塞中返回
#include <pthread.h>
#include <semaphore.h>
#include <stdio.h>
#include <stdlib.h>
typedef struct
{
int res;
sem_t sem;
}Result;
//计算并将结果放置Result中的线程运行函数
void *set_fn(void *arg)
{
int i =1,sum = 0;
for(;i<=100;i++){
sum +=i;
}
Result *r = (Result *)arg;
//将计算结果放置到Result的res中
r->res = sum;
//v(1)操作
sem_post(&r->sem);
return (void *)0;
}
//获得结果的线程运行函数
void *get_fn(void *arg)
{
Result *r = (Result *)arg;
//p(1)操作
sem_wait(&r->sem);
//获取计算结果
int res = r->res;
printf("0x%lx get sum is %d\n",pthread_self(),res);
return (void *)0;
}
int main(void)
{
int err;
pthread_t cal,get;
Result r;
sem_init(&r.sem,0,0);//初始化信号量,初值为0
//启动获取结果的线程
if((err = pthread_create(&get,NULL,get_fn,(void*)&r)) != 0){
perror("pthread create error");
}
//启动计算结果的线程
if((err = pthread_create(&cal,NULL,set_fn,(void*)&r)) != 0){
perror("pthread create error");
}
pthread_join(cal,NULL);
pthread_join(get,NULL);
sem_destroy(&r.sem);
return 0;
}