Я хочу, чтобы некоторые конвертировали мой код языка C в Bash / Shell Script [closed]

Проблема производителя и потребителя — это общая парадигма взаимодействующих процессов. Процесс производителя производит информацию, которая потребляется процессом потребителя. Одно из решений проблемы производитель-потребитель использует разделяемую память. Чтобы процессы производителя и потребителя могли выполняться одновременно, должен быть доступен буфер элементов, который может быть заполнен производителем и опустошен потребителем. Этот буфер будет находиться в области памяти, которая совместно используется процессами производителя и потребителя. Производитель может производить один товар, в то время как потребитель потребляет другой товар. Производитель и потребитель должны быть синхронизированы, чтобы потребитель не пытался потреблять товар, который еще не был произведен. Напишите сценарий bash для моделирования проблемы производителя-потребителя с использованием семафоров.

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

/*
This program provides a possible solution for producer-consumer problem using mutex and semaphore.
I have used 5 producers and 5 consumers to demonstrate the solution. You can always play with these values.
*/

#define MaxItems 5 // Maximum items a producer can produce or a consumer can consume
#define BufferSize 5 // Size of the buffer

sem_t empty;
sem_t full;
int in = 0;
int out = 0;
int buffer[BufferSize];
pthread_mutex_t mutex;

void *producer(void *pno)
{   
    int item;
    for(int i = 0; i < MaxItems; i++) {
        item = rand(); // Produce an random item
        sem_wait(&empty);
        pthread_mutex_lock(&mutex);
        buffer[in] = item;
        printf("Producer %d: Insert Item %d at %dn", *((int *)pno),buffer[in],in);
        in = (in+1)%BufferSize;
        pthread_mutex_unlock(&mutex);
        sem_post(&full);
    }
}
void *consumer(void *cno)
{   
    for(int i = 0; i < MaxItems; i++) {
        sem_wait(&full);
        pthread_mutex_lock(&mutex);
        int item = buffer[out];
        printf("Consumer %d: Remove Item %d from %dn",*((int *)cno),item, out);
        out = (out+1)%BufferSize;
        pthread_mutex_unlock(&mutex);
        sem_post(&empty);
    }
}

int main()
{   

    pthread_t pro[5],con[5];
    pthread_mutex_init(&mutex, NULL);
    sem_init(&empty,0,BufferSize);
    sem_init(&full,0,0);

    int a[5] = {1,2,3,4,5}; //Just used for numbering the producer and consumer

    for(int i = 0; i < 5; i++) {
        pthread_create(&pro[i], NULL, (void *)producer, (void *)&a[i]);
    }
    for(int i = 0; i < 5; i++) {
        pthread_create(&con[i], NULL, (void *)consumer, (void *)&a[i]);
    }

    for(int i = 0; i < 5; i++) {
        pthread_join(pro[i], NULL);
    }
    for(int i = 0; i < 5; i++) {
        pthread_join(con[i], NULL);
    }

    pthread_mutex_destroy(&mutex);
    sem_destroy(&empty);
    sem_destroy(&full);

    return 0;
    
}

1 ответ
1

Я бы просто использовал трубку.
Тогда вся синхронизация и буферизация сделаются за вас прозрачно.

  • 6

    Пожалуйста, воздержитесь от ответов на некачественные вопросы, которые могут быть закрыты. После того, как вы ответили, это ограничивает то, что можно сделать для улучшения вопроса, повышая вероятность того, что ваши усилия будут потрачены впустую. Лучше подождать, пока вопрос будет правильно готов, прежде чем отвечать!

    — Тоби Спейт

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *