왜 내 코드 디스플레이의 출력의 처음 몇 반복에 대해 소비자가 처음 두 항목을 소비해야 할 때 두 번 소비합니까? 여기C 생산자 소비자 세마포어를 사용하여
Consumer consumes 0
Producer produces 17
Producer produces 17
Consumer consumes 0
Producer produces 10
Producer produces 12
Consumer consumes 10
Producer produces 11
Producer produces 43
Consumer consumes 12
Producer produces 33
Producer produces 39
Consumer consumes 11
는
#define N 10
typedef int semaphore;
semaphore mutex, full, empty;
int first=0,last=0, semArray[N];
를 표시하는 내 코드의 일부입니다 그 전역 변수의 사용을 수 있을까?
int produce_item(){
int item = rand()%50 +1;
printf("Producer produces %d\n",item);
sleep(1);
return item;
}
void consume_item(int item){
printf("Consumer consumes %d\n",item);
sleep(2);
}
int remove_item(){
int temp = semArray[first];
first = first +1;
return temp;
}
void insert_item(int item){
semArray[last] = item;
last++;
}
이
는 세마포어 에 대한 생산자와 소비자 기능입니다void* consumer(void* arg) {
int item, i=0;
while(1){
down(full);
down(mutex);
item = remove_item();
up(mutex);
up(empty);
consume_item(item);
}
return 0;
}
void* producer(void* arg) {
int item, i=0;
while(1){
item=produce_item();
down(empty);
down(mutex);
insert_item(item);
up(mutex);
up(full);
}
return 0;
}
void down(semaphore s){
setSemaphore(s,0,-1);
}
void up(semaphore s){
setSemaphore(s,0,1);
}
int setSemaphore(int semID, int semNum, int semOp){
struct sembuf Buf;
Buf.sem_num = semNum;
Buf.sem_op = semOp;
Buf.sem_flg = 0;
return semop(semID,&Buf,1);
}
main() {
int i;
pthread_t threads[2];
srand(time(NULL));
int semid_full, semid_empty, semid_mutex;
key_t key;
key = ftok("task2.c", 'J');
//initialize and create each semaphore set
semid_empty = semget(key, 1, 0600|IPC_CREAT);
arg.val = N;
semctl(semid_empty, 0, SETVAL, arg);
semid_full = semget(key, 1, 0600|IPC_CREAT);
arg.val = 0;
semctl(semid_empty, 0, SETVAL, arg);
semid_mutex = semget(key, 1, 0600|IPC_CREAT);
arg.val = 1;
semctl(semid_mutex, 0, SETVAL, arg);
pthread_create(&threads[0],NULL,consumer,NULL);
pthread_create(&threads[1],NULL,producer,NULL);
//remove
semctl(semid_empty, 0 , IPC_RMID, arg);
semctl(semid_full, 0, IPC_RMID,arg);
semctl(semid_mutex, 0 , IPC_RMID, arg);
for(i=0; i<2; i++) {
pthread_join(threads[i],NULL);
}
[MCVE]를 제공해주십시오. 현재 예제는'main()'함수를 포함하지 않고'up()'과'down()'을 구현하지도 않는다. (세마포어에'typedef '를 주면된다. – EOF