FINAL GRADE: 100/100
- Multithreading
- Synchronization
Welcome to the 42 Philosophers project! This repository contains my implementation of the classic dining philosophers problem as part of the curriculum at 42 School. The dining philosophers problem is a fundamental synchronization problem in computer science, illustrating the challenges of avoiding deadlock and ensuring concurrency in a multi-threaded environment.
Project goal: To create a simulation of the dining philosophers problem, demonstrating threading, mutexes, and concurrent processing.
In the mandatory part, each philosopher is a thread and each fork is protected by a mutex. There is exactly one fork between each philosopher and a philosopher must take the forks to his immediate left and right in order to eat. The goal is to manage resource allocation (forks) among multiple philosophers, ensuring no philosopher starves and preventing deadlock.
- Each philosopher should be a thread.
- Forks are shared resources protected by mutexes.
- Philosophers should alternately eat, think, and sleep.
- The program must handle proper termination and avoid data races.
Note: This project covers only the mandatory requirements.
-
Clone the Repository:
git clone https://github.com/prosviriakova/Philosophers.git philo cd philo
-
Build the Project:
make
-
Run the Simulation:
./philo number_of_philosophers time_to_die time_to_eat time_to_sleep [number_of_times_each_philosopher_must_eat]
number_of_philosophers
: The number of philosophers and forks.time_to_die
(in milliseconds): Time a philosopher can go without eating before dying.time_to_eat
(in milliseconds): Time a philosopher spends eating.time_to_sleep
(in milliseconds): Time a philosopher spends sleeping.[number_of_times_each_philosopher_must_eat]
(optional): Number of times each philosopher must eat before the simulation ends.
The arguments must be integers between 0 and INT_MAX representing a time in milliseconds. For example:
./philo 4 800 200 200 5
To visualize the philosophers' simulation, you can use the Philosophers Visualizer. This is a simple web-based tool to visualize the dining philosophers' activities, such as eating, thinking, and sleeping.
To test how precise the usleep
function is on your system, there are two test scripts provided in the test/
folder:
-
C Test (
usleep_test.c
):- Compile and run the C test for
usleep
:
gcc usleep_test.c -o usleep_test ./usleep_test
This will check how accurately the
usleep
function works in your environment by measuring the actual delay compared to the requested one. - Compile and run the C test for
-
Python Test (
delay_o_meter.py
):- Run the Python test:
python3 delay_o_meter.py
This script will perform 20 measurements of a 200 ms sleep and calculate the average additional delay added by the system.
Contributions are welcome! If you have any suggestions or improvements, feel free to create an issue or submit a pull request.
Subject version: 11.