sem_t
sem_init
sem_wait
sem_trywait
sem_timedwait
sem_post
sem_destroy

生产者消费者实例:

#include <stdlib.h>
#include <pthread.h>
#include <stdio.h>
#include <semaphore.h>
#define NUM 5 int queue[NUM]; sem_t blank_number, product_number;
void *producer(void *arg) {   int p = 0;   while (1) {     sem_wait(&blank_number);     queue[p] = rand() % 1000 + 1;     printf("Produce %d\n", queue[p]);     sem_post(&product_number);     p = (p+1)%NUM;     sleep(rand()%5);   }
}
void *consumer(void *arg) {   int c = 0;   while (1) {     sem_wait(&product_number);     printf("Consume %d\n", queue[c]);     queue[c] = 0;       sem_post(&blank_number);     c = (c+1)%NUM;     sleep(rand()%5);   } }
int main(int argc, char *argv[]) {   pthread_t pid, cid;   sem_init(&blank_number, 0, NUM);   sem_init(&product_number, 0, 0);   pthread_create(&pid, NULL, producer, NULL);   pthread_create(&cid, NULL, consumer, NULL);   pthread_join(pid, NULL);   pthread_join(cid, NULL);   sem_destroy(&blank_number);   sem_destroy(&product_number);   return 0; }

 

相关文章:

  • 2022-01-16
  • 2021-11-03
  • 2021-05-08
  • 2021-07-26
  • 2021-09-30
  • 2021-10-11
  • 2021-09-07
猜你喜欢
  • 2021-12-01
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-08-11
  • 2021-08-07
相关资源
相似解决方案