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;
} 
相关推荐
如竟没有火炬3 小时前
四数相加贰——哈希表
数据结构·python·算法·leetcode·散列表
背心2块钱包邮3 小时前
第9节——部分分式积分(Partial Fraction Decomposition)
人工智能·python·算法·机器学习·matplotlib
仰泳的熊猫3 小时前
1148 Werewolf - Simple Version
数据结构·c++·算法·pat考试
chao1898443 小时前
MATLAB中的多重网格算法与计算流体动力学
开发语言·算法·matlab
爱宇阳3 小时前
Linux 安全加固:禁用 IPv4 ICMP 重定向发送
linux·运维·安全
大工mike3 小时前
代码随想录算法训练营第四十四天 | 99.岛屿数量 深搜 99.岛屿数量 广搜 100. 岛屿的最大面积
算法
阿豪学编程3 小时前
动静态库制作与原理
linux·个人开发
2401_861786183 小时前
linux修改ip地址(有详细步骤)kali
linux·运维·服务器
颜子鱼3 小时前
Linux platform总线驱动框架
linux·驱动开发
不穿格子的程序员3 小时前
从零开始学算法——链表篇3:合并两个有序链表 + 两数相加
数据结构·算法·链表·dummy