IO进程线程第七天(8.4)信号量,条件变量

在第一题的基础上加上一个需求:要求打印,倒置线程,顺序执行。出现的现象为先打印1234567,后打印7654321(不使用flag)

创建两个线程,其中一个线程读取文件中的数据,另外一个线程将读取到的内容打印到终端上,类似实现cat一个文件。

cat数据完毕后,要结束两个线程。

提示:先读数据,读到数据后将数据打印到终端上。

cpp 复制代码
#include<stdio.h>
#include<head.h>
char buf[]="1234567";
sem_t sem1,sem2;
void *myprintf(void *arg)
{
    int count=0;
    while(1)
    {
        if(sem_wait(&sem1)<0)//p操作
        {
            ERR_MSG("sem_wait");
            return NULL;
        }
        printf("%s\n",buf);
        if(sem_post(&sem2)<0)//v操作
        {
            ERR_MSG("sem_post");
            return NULL;
        }
    }                                                                                                                                               
    pthread_exit(NULL);
}
void *strrev(void *arg)
{
    char t;
    while(1)
    {
        if(sem_wait(&sem2)<0)//p操作
        {
            ERR_MSG("sem_wait");
            return NULL;
        }
        for(int i=0;i<strlen(buf)/2;i++)
        {
            t=buf[i];
            buf[i]=buf[strlen(buf)-1-i];
            buf[strlen(buf)-1-i]=t;
        }
        if(sem_post(&sem1)<0)//v操作
        {
            ERR_MSG("sem_post");
            return NULL;
        }
    }
    pthread_exit(NULL);
}
int main(int argc, const char *argv[])
{
    if(sem_init(&sem1,0,1)<0)
    {
        ERR_MSG("sem_inti");
        return -1;
    }
    if(sem_init(&sem2,0,0)<0)
    {
        ERR_MSG("sem_inti");
        return -1;
    }

    pthread_t tid1,tid2;
    if(pthread_create(&tid1,NULL,myprintf,NULL)!=0)
    {
        fprintf(stderr,"pthread_create failed __%d__\n",__LINE__);
        return -1;
    }
    if(pthread_create(&tid2,NULL,strrev,NULL)!=0)
    {
        fprintf(stderr,"pthread_create failed __%d__\n",__LINE__);
        return -1;
    }
    pthread_join(tid2,NULL);
    sem_destroy(&sem1);
    sem_destroy(&sem2);
    return 0;
}
cpp 复制代码
#include<stdio.h>
#include<head.h>
char c;
ssize_t res;
sem_t sem1,sem2;
void *myread(void *arg)
{
    int fp=open("ABC.c",O_RDONLY);
    if(fp<0)
    {
        ERR_MSG("open");
        return NULL;
    }
    while(1)
    {
        if(sem_wait(&sem1)<0)
        {
            ERR_MSG("sem_wait");
            return NULL;
        }           
        res=read(fp,&c,1); 
        if(0==res)
        {
            if(sem_post(&sem2)<0)
            {
                ERR_MSG("sem_post");
                return NULL;
            }
            break;
        }
        if(sem_post(&sem2)<0)
        {
            ERR_MSG("sem_post");
            return NULL;
        }
    }
}
void *mywrite(void *arg)
{
    while(1)
    {
        if(sem_wait(&sem2)<0)
        {
            ERR_MSG("sem_wait");
            return NULL;
        }
        write(1,&c,res);
        if(0==res)
        {
            if(sem_post(&sem1)<0)
            {
                ERR_MSG("sem_post");
                return NULL;
            }
            break;
        }
        if(sem_post(&sem1)<0)
        {
            ERR_MSG("sem_post");
            return NULL;
        }
    }
}
int main(int argc, const char *argv[])
{
    if(sem_init(&sem1,0,1)<0)
    {
        ERR_MSG("sem init");                                                                                                                                                                                                                                                                    
        return -1;
    }
    if(sem_init(&sem2,0,0)<0)
    {
        ERR_MSG("sem init");
        return -1;
    }
    pthread_t tid1,tid2;
    if(pthread_create(&tid1,NULL,myread,NULL)!=0)
    {
        fprintf(stderr,"pthread_create failed __%d__\n",__LINE__);
        return -1;
    }
    if(pthread_create(&tid2,NULL,mywrite,NULL)!=0)
    {
        fprintf(stderr,"pthread_create failed __%d__\n",__LINE__);
        return -1;
    }
    pthread_join(tid1,NULL);
    pthread_join(tid2,NULL);
    sem_destroy(&sem1);
    sem_destroy(&sem2);
    return 0;
} 
相关推荐
气质、小青年!6 分钟前
【排序算法】
c语言·数据结构
智者知已应修善业34 分钟前
【51单片机节日彩灯控制器设计】2022-6-11
c语言·经验分享·笔记·单片机·嵌入式硬件·51单片机
眠修1 小时前
Kuberrnetes 服务发布
linux·运维·服务器
重庆小透明1 小时前
力扣刷题记录【1】146.LRU缓存
java·后端·学习·算法·leetcode·缓存
开-悟1 小时前
嵌入式编程-使用AI查找BUG的启发
c语言·人工智能·嵌入式硬件·bug
desssq1 小时前
力扣:70. 爬楼梯
算法·leetcode·职场和发展
clock的时钟2 小时前
暑期数据结构第一天
数据结构·算法
小小小小王王王2 小时前
求猪肉价格最大值
数据结构·c++·算法
岁忧3 小时前
(LeetCode 面试经典 150 题 ) 58. 最后一个单词的长度 (字符串)
java·c++·算法·leetcode·面试·go
BIYing_Aurora3 小时前
【IPMV】图像处理与机器视觉:Lec13 Robust Estimation with RANSAC
图像处理·人工智能·算法·计算机视觉