Я получаю предупреждения для семафоров - PullRequest
0 голосов
/ 05 апреля 2019

Итак, я весь день работал над этим проектом, я проверял ошибки, которые у меня есть, и, исправляя их, я пришел к последней части, которая является предупреждениями.

предупреждениями о том, что я являюсьполучение аналогично: передача аргумента 1 из '' из совместимого типа указателя [включено по умолчанию] примечание: ожидается 'union sem_t *', но аргумент имеет тип 'void * () (void )'

пожалуйста, просто помогите мне.Я застрял на этом в течение нескольких часов.заранее спасибо!

Я снял & sem_init как у клиентов, так и у парикмахеров, но это не сработало.

    #include <unistd.h> //Provides API for POSIX(or UNIX) OS for system calls
    #include <stdio.h> //Standard I/O Routines
    #include <stdlib.h> //For exit() and rand()
    #include <pthread.h> //Threading APIs
    #include <semaphore.h> //Semaphore APIs

    #define MAX 30 //Maximum no. of customers for simulation
    #define MAX_BARBERS 1000

    sem_t customer; //Semaphore
    sem_t barber; //Semaphore
    sem_t mutex; //Semaphore for providing mutially exclusive access

    void *barbers(void *param); //Thread Function
    void *customers(void *param); //Thread Function

    int num_chairs;
    int barbers_total;
    int customers_total;
    int serveMeNext; //Index to choose a candidate for cutting hair

    void wait(); //Randomized delay function

    int main(int argc, char *argv[]){

      pthread_t barberid[MAX_BARBERS];
      pthread_t customerid[MAX]; //Thread declaration
      int i = 0;

      if(argc != 4){
        printf("Enter 3 arguments (Number of chairs, barbers, customers)\n");
        exit(0);
      }

      num_chairs = atoi(argv[1]);
      barbers_total = atoi(argv[2]);
      customers_total = atoi(argv[3]);
    ''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
      /*Semaphore initialization*/
      sem_init(&mutex,0,1);
      sem_init(customers,0,0);
      sem_init(barbers,0,0);
''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
      /*Barber thread initialization*/
      printf("!!Barber Shop Opens!!\n");

      for(i = 0; i <= barbers_total; i++){ //Creation of barbers    
''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
         pthread_create(&barberid[i], NULL, barbers, (void*)&i);
''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
         sleep(1);
      }

      /*Customer thread initialization*/
      for(i = 0; i <= customers_total; i++){ //Creation of Customer Threads 
''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''  
         pthread_create(&customerid[i],NULL,customers,(void*)&i);
''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
         wait(); //Create customers in random interval
      }
      for(i = 0; i <= MAX; i++) //Waiting till all customers are dealt with

       pthread_join(customerid[i],NULL);
       printf("!!Barber Shop Closes!!\n");
       exit(EXIT_SUCCESS);  //Exit abandoning infinite loop of barber thread
    }

    void *customers(void *param){ /*Customer Process*/

      int mySeat, B;
      static int count = 0; //Counter of No. of customers
      int numberOfFreeSeats = num_chairs; //Counter for Vacant seats in waiting room
      int seatPocket[num_chairs]; //To exchange pid between customer and barber
      int sitHereNext = 0; //Index for next legitimate seat
      serveMeNext = 0;
      sem_wait(&mutex); //Lock mutex to protect seat changes
      count++; //Arrival of customer

      printf("Customer-%d entered shop. ",count);

      if(numberOfFreeSeats > 0){
          --numberOfFreeSeats; //Sit on chairs on waiting room

        printf("Customer-%d Sits In Waiting Room.\n",count);

        sitHereNext = (++sitHereNext) % num_chairs; //Choose a vacant chair to sit

        mySeat = sitHereNext;
        seatPocket[mySeat] = count;

        sem_post(&mutex); //Release the seat change mutex
        sem_post(barbers); //Wake up one barber
        sem_wait(customers); //Join queue of sleeping customers
        sem_wait(&mutex); //Lock mutex to protect seat changes

        B = seatPocket[mySeat]; //Barber replaces customer PID with his own PID

        numberOfFreeSeats++; //Stand Up and Go to Barber Room

        sem_post(&mutex); //Release the seat change mutex
        /*Customer is having hair cut by barber 'B'*/
      }else{
        sem_post(&mutex); //Release the mutex and customer leaves without haircut  
        printf("Customer-%d Finds No Seat & Leaves.\n",count);
      }
      pthread_exit(0);
    }

    void *barbers(void *param){ /*Barber Process*/

      int index = *(int *)(param);
      int myNext, C;
      int worktime;
      int seatPocket[num_chairs]; //To exchange pid between customer and barber  

      printf("Barber-%d joins shop. ",index);

      while(1){ /*Infinite loop*/
        printf("Barber-%d Gone To Sleep.\n",index);

        sem_wait(barbers); //Join queue of sleeping barbers
        sem_wait(&mutex); //Lock mutex to protect seat changes

        serveMeNext = (++serveMeNext) % MAX; //Select next customermyNext = serveMeNext;

        C = seatPocket[myNext]; //Get selected customer's PID
        seatPocket[myNext] = pthread_self(); //Leave own PID for customer

        sem_post(&mutex);
        sem_post(customers); //Call selected customer

       /*Barber is cutting hair of customer 'C'*/
        printf("Barber-%d Wakes Up & Is Cutting Hair Of Customer-%d.\n",index,C);
        worktime = (rand() % 3) + 1;
        printf("Barber-%d Finished.\n",index);
        sleep(worktime);
      }
    }

    void wait(){ /*Generates random number between 50000 to 250000*/
      int x = rand() % (250000 - 50000 + 1) + 50000;
      srand(time(NULL));
      usleep(x); //usleep halts execution in specified miliseconds
    }

Я отметил "" "места, где, как мне кажется, яЯ ошибаюсь из-за исследования, которое я проводил.

1 Ответ

1 голос
/ 05 апреля 2019

Из предупреждения видно, что вы передавали указатель на функцию вместо ожидаемого типа sem_t.

У вас, похоже, была опечатка с customer и barber.

sem_init должно быть

sem_init(&customer,0,0);      
sem_init(&barber,0,0);

А ваш sem_post должен быть

sem_post(&customer);
sem_post(&barber);

Также не забудьте скомпилировать это с -lpthread или -pthread

...