我正在通过实现生产者消费者问题来学习并发编程。该代码只有一个生产者和一个消费者。使用者线程坐在一个空的信号量中阻塞的while循环中。该代码生成了我无法调试的segfault 11。我尝试删除使用者线程中的while循环,此后我看不到segfault为什么会这样?
#include <iostream>
#include <cstdlib>
#include <pthread.h>
#include <queue>
#include <unistd.h>
#include <semaphore.h>
using namespace std;
queue<int> buff;
pthread_mutex_t mut = PTHREAD_MUTEX_INITIALIZER;
sem_t empty;
void producer(int i){
pthread_mutex_lock(&mut);
buff.push(i);
sem_post(&empty);
pthread_mutex_unlock(&mut);
}
void* produce_data(void* arg){
for(int i = 5 ; i < 10 ; i++){
producer(i);
}
return NULL;
}
void* consumer(void* arg){
while(1){
sem_wait(&empty);
pthread_mutex_lock(&mut);
int temp = buff.front();
cout << temp <<" " ;
buff.pop();
pthread_mutex_unlock(&mut);
}
return 0;
}
int main () {
pthread_t prod;
sem_init(&empty, 0, 0);
pthread_create(&prod, NULL, produce_data , NULL);
pthread_t consum2;
pthread_create(&consum2, NULL,consumer , NULL);
pthread_join(prod,NULL);
pthread_join(consum2,NULL);
return 0;
}
答案 0 :(得分:0)
Sem_init()在macOS中已弃用。编译程序应该已经显示了这一点。另外,如果检查了返回值,您将知道sem_init(),sem_post()和sem_wait()都失败了。无论出于何种原因,您的队列中都会弹出1023左右的位置,它就是SEGV。