【操作系统】实验一 进程间通信

初步接触linux系统。
时间:2020-11-24

①无名管道通信验证
在这里插入图片描述

无名管道不能实现不是父子进程(亲缘关系)之间的通信.
上述进程有先后条件制约关系,且在同一个main方法内,公用一个管道.但是两个进程之间完全没有关系的时候==>两个不同的管道,就无法实现父子进程之间的通信

②信号通信验证
在这里插入图片描述

设计性工作:父亲儿子女儿放取水果进程/线程间通信程序设计与实现
问题描述:桌上有一空盘,最多允许存放一个水果。父亲可向盘中放一个苹果或放一个桔子,儿子专等吃盘中的桔子,女儿专等吃苹果,当儿子或女儿取完水果后,父亲又可再放。试选择一种Linux下的进程间通信方式实现系统中三个进程/线程的执行关系控制。

在这里插入图片描述
部分代码:

#include <stdlib.h>
#include <pthread.h>
#include <stdlib.h>
#include <unistd.h>
#include <stdio.h>
#include <semaphore.h>

typedef struct{
    int     frt_tp;
    sem_t   sem_product;
    sem_t   sem_space;
    pthread_mutex_t mutex;
}frt_sem_mtx_def;


/*  父亲线程:盘子中为空,则随机添加水果
    frt_tp值为1-橘子,2-苹果
    对frt_tp进行资源加锁,更改后,释放锁
*/
void* fun_father(void* arg)
{
    frt_sem_mtx_def *frt = (frt_sem_mtx_def*)arg;
    int cnt = 0;
    while (1)
    {
        sem_wait(&frt->sem_space);
        sem_post(&frt->sem_product);

        sem_getvalue(&frt->sem_product, &cnt);
        pthread_mutex_lock(&frt->mutex);
        frt->frt_tp = rand()%2+1;
        pthread_mutex_unlock(&frt->mutex);
        if(frt->frt_tp==1){
printf("父亲 向盘中添加 橘子\n");
}else{
printf("父亲 向盘中添加 苹果\n");

}
        //printf("父亲 向盘中添加 苹果");
        //printf("father Thread 0x%lx put %d fruit, count:%d\n", pthread_self(), frt->frt_tp, cnt);

        sleep(1);
    }
}

/*  儿子线程:加锁访问frt_tp值
    若值是1,则对盘子中水果减一,对盘子空间加一
    重置frt_tp为0,最后释放锁
*/
void* fun_son(void* arg)
{
    frt_sem_mtx_def *frt = (frt_sem_mtx_def*)arg;

    int p_cnt = 0;
    int s_cnt = 0;
    
    while (1)
    {
        pthread_mutex_lock(&frt->mutex);
        if (frt->frt_tp == 1)
        {
            //对产品个数减一
            sem_wait(&frt->sem_product);
            //相应的空间加一
            sem_post(&frt->sem_space);
            sem_getvalue(&frt->sem_product, &p_cnt);
            sem_getvalue(&frt->sem_space, &s_cnt);
             printf("儿子 从盘中取走 橘子\n");
            //printf("Son Thread 0x%lx take %d fruit, p_cnt:%d, s_cnt:%d\n", pthread_self(),frt->frt_tp, p_cnt, s_cnt);
            frt->frt_tp = 0;
        }
        pthread_mutex_unlock(&frt->mutex);
        sleep(1);
    }
    return (void*)0;
}

/*  女儿线程:加锁访问frt_tp值
    若值是2,则对盘子中水果减一,对盘子空间加一
    重置frt_tp为0,最后释放锁
*/
void* fun_dau(void* arg)
{
    int p_cnt = 0;
    int s_cnt = 0;
    frt_sem_mtx_def *frt = (frt_sem_mtx_def*)arg;

    while (1)
    {
        pthread_mutex_lock(&frt->mutex);
        if (frt->frt_tp == 2)
        {
            //对产品个数减一
            sem_wait(&frt->sem_product);
            //相应的空间加一
            sem_post(&frt->sem_space);
            sem_getvalue(&frt->sem_product, &p_cnt);
            sem_getvalue(&frt->sem_space, &s_cnt);
            printf("女儿 从盘中取走 苹果\n");
            //printf("dau Thread 0x%lx take %d fruit, p_cnt:%d, s_cnt:%d\n", pthread_self(), frt->frt_tp, p_cnt, s_cnt);
            frt->frt_tp = 0;
        }

        pthread_mutex_unlock(&frt->mutex);
        sleep(1);

    }

    return (void*)0;
}//完整代码请看git

git:operateSystemTest_实验一

  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值