目录
1.创建两个线程 A、B,要求A线程读取文件中的数据,B线程将读取到的数据打印到终端上,类似shell命令cat。
2.编写一个程序,开启3个线程,这3个线程的ID分别为A、B、C,每个线程将自己的ID在屏幕上打印10遍,要求输出结果必须按ABC的顺序显示,如ABC ABC……依次递推;
1.创建两个线程 A、B,要求A线程读取文件中的数据,B线程将读取到的数据打印到终端上,类似shell命令cat。
代码:
#include <stdio.h>
#include <unistd.h>
#include <semaphore.h>
#include <pthread.h>
#include <string.h>
char str[100]="";
pthread_mutex_t mutex;
pthread_cond_t cond;
int flag=0;
void* rd(void *arg)
{
FILE* fp=fopen("./1.c","r");
if(NULL==fp)
{
perror("fopen");
pthread_exit(NULL);
}
while(1)
{
pthread_mutex_lock(&mutex);
if(0!=flag)
{
pthread_cond_wait(&cond,&mutex);
}
pthread_cond_signal(&cond);
pthread_mutex_unlock(&mutex);
if(fgets(str,sizeof(str),fp)==NULL)
{
break;
}
pthread_cond_signal(&cond);
flag=1;
pthread_mutex_unlock(&mutex);
}
fclose(fp);
pthread_exit(NULL);
}
void* wt(void *arg)
{
while(1)
{
pthread_mutex_lock(&mutex);
if(1!=flag)
{
pthread_cond_wait(&cond,&mutex);
}
if(strlen(str)==0)
break;
printf("%s",str);
fflush(stdout);
bzero(str,sizeof(str));
flag=0;
pthread_cond_signal(&cond);
pthread_mutex_unlock(&mutex);
}
pthread_exit(NULL);
}
int main(int argc, const char *argv[])
{
pthread_mutex_init(&mutex,NULL);
pthread_t tid1,tid2;
if(pthread_create(&tid1,NULL,rd,NULL)!=0)
{
perror("pthread_create");
return -1;
}
if(pthread_create(&tid2,NULL,wt,NULL)!=0)
{
perror("pthread_create");
return -1;
}
pthread_join(tid1,NULL);
pthread_join(tid2,NULL);
pthread_mutex_destroy(&mutex);
if(pthread_cond_destroy(&cond)!=0)
{
perror("pthread_cond_destroy");
return -1;
}
return 0;
}
终端输出结果:
2.编写一个程序,开启3个线程,这3个线程的ID分别为A、B、C,每个线程将自己的ID在屏幕上打印10遍,要求输出结果必须按ABC的顺序显示,如ABC ABC……依次递推;
代码:
#include <stdio.h>
#include <unistd.h>
#include <pthread.h>
pthread_mutex_t mutex;
pthread_cond_t cond1,cond2;
int flag=0;
void*A(void*arg)
{
//A线程
int i=0;
while(i<10)
{
pthread_mutex_lock(&mutex);
if(0!=flag)
{
pthread_cond_wait(&cond1,&mutex);
}
printf("A");
i++;
flag=1;
pthread_cond_signal(&cond1);
pthread_mutex_unlock(&mutex);
}
pthread_exit(NULL);
}
void*B(void*arg)
{
//B线程
int i=0;
while(i<10)
{
pthread_mutex_lock(&mutex);
if(1!=flag)
{
//条件变量1休眠
pthread_cond_wait(&cond1,&mutex);
}
printf("B");
i++;
flag=2;
//唤醒条件变量2
pthread_cond_signal(&cond2);
pthread_mutex_unlock(&mutex);
}
pthread_exit(NULL);
}
void*C(void*arg)
{
//C线程
int i=0;
while(i<10)
{
pthread_mutex_lock(&mutex);
if(2!=flag)
{
//条件变量2休眠
pthread_cond_wait(&cond2,&mutex);
}
printf("C");
printf("\n");
i++;
flag=0;
//唤醒条件变量1
pthread_cond_signal(&cond1);
pthread_mutex_unlock(&mutex);
}
pthread_exit(NULL);
}
int main(int argc, const char *argv[])
{
pthread_mutex_init(&mutex,NULL);
pthread_t tid1,tid2,tid3;
if(pthread_create(&tid1,NULL,A,NULL)!=0)
{
perror("pthread_create");
return -1;
}
if(pthread_create(&tid2,NULL,B,NULL)!=0)
{
perror("pthread_create");
return -1;
}
if(pthread_create(&tid3,NULL,C,NULL)!=0)
{
perror("pthread_create");
return -1;
}
pthread_join(tid1,NULL);
pthread_join(tid2,NULL);
pthread_join(tid3,NULL);
//销毁互斥锁、条件变量1,2
pthread_mutex_destroy(&mutex);
pthread_cond_destroy(&cond1);
pthread_cond_destroy(&cond2);
return 0;
}
终端输出结果: