Я изучал параллельное программирование, реализуя проблему производителя-потребителя. В коде есть только один производитель и один потребитель. Потребительский поток находится в цикле 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;
}
sem_post
за пределы мьютекса. - person stark   schedule 09.03.2020cout
приводит к ожидаемому результату, за которым следует зависание, поскольку один поток находится вpthread_join
, а другой — в бесконечном циклеwhile
. - person David Schwartz   schedule 09.03.2020-pthread
или что-то подобное для компиляции кода, использующего стандарт pthreads? - person David Schwartz   schedule 09.03.2020