fix: check if all threads is stopped before destroye data
This commit is contained in:
19
data.c
19
data.c
@ -2,6 +2,7 @@
|
||||
#include <stdbool.h>
|
||||
#include <stddef.h>
|
||||
#include <stdlib.h>
|
||||
#include <unistd.h>
|
||||
#include "./data.h"
|
||||
#include "philo.h"
|
||||
#include "philos.h"
|
||||
@ -35,9 +36,23 @@ bool data_init(t_data *data)
|
||||
|
||||
void data_destroyer(t_data *data)
|
||||
{
|
||||
free(data->threads);
|
||||
free(data->forks);
|
||||
size_t i;
|
||||
t_philo *philo;
|
||||
bool stop;
|
||||
|
||||
i = 0;
|
||||
while (i < data->nb_philos)
|
||||
{
|
||||
philo = data->philos[i];
|
||||
pthread_mutex_lock(&philo->stop_mutex);
|
||||
stop = philo->stop;
|
||||
pthread_mutex_unlock(&philo->stop_mutex);
|
||||
if (stop)
|
||||
i++;
|
||||
}
|
||||
pthread_mutex_destroy(&data->forks_mutex);
|
||||
pthread_mutex_destroy(&data->stop_mutex);
|
||||
free(data->threads);
|
||||
free(data->forks);
|
||||
philos_destroyer(data);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user