用信号量的方式,创建两个线程 A B
- A线程读取文件中的内容
- B线程打印A读取到的内容到终端,
- 全部打印完毕后,结束进程;
- 现象类似cat一个文件
#include <stdio.h>
#include <pthread.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <errno.h>
#include <semaphore.h>
#define LEN 20
struct filecat
{
char str[LEN]; // 搬运字符串
int fr; // 读取文件标识符
int rl; // 单次读取长
sem_t s1m; // 信号量
sem_t s2m;
};
void *rpt(void *fs) // 读线程
{
struct filecat *f=(struct filecat *)fs;
do{
sem_wait(&(f->s1m));
f->rl=read(f->fr,f->str,LEN);
sem_post(&(f->s2m));
}while(f->rl);
pthread_exit(NULL);
}
void *cpt(void *fs) // 写线程
{
struct filecat *f=(struct filecat *)fs;
do{
sem_wait(&(f->s2m));
write(1,f->str,f->rl); // stdout->1
sem_post(&(f->s1m));
}while(f->rl);
pthread_exit(NULL);
}
int main(int argc, const char *argv[])
{
struct filecat fs;
fs.fr=open(argv[1],O_RDONLY);
// 创建信号量
if(sem_init(&fs.s1m,0,1)){
perror("s1m:");
return 0;
}
if(sem_init(&fs.s2m,0,0)){
perror("s2m:");
return 0;
}
// 创建线程
pthread_t rid,cid;
if(pthread_create(&rid,NULL,rpt,&fs)){
printf("rpt error\n");
return 0;
}
if(pthread_create(&cid,NULL,cpt,&fs)){
printf("cpt error\n");
return 0;
}
pthread_join(rid,NULL);
pthread_join(cid,NULL);
sem_destroy(&fs.s1m);
sem_destroy(&fs.s2m);
close(fs.fr);
return 0;
}