The prompt usually reads something like: Write a program that takes a number_of_philosophers and a time_to_die as arguments. Each philosopher is a process. They must eat, sleep, and think. If a philosopher doesn’t start eating before time_to_die milliseconds after their last meal, they die and the simulation stops. | Feature | Exam 03 (Minishell) | Exam 04 (Microshell) | Exam 06 (Philosophers) | | :--- | :--- | :--- | :--- | | Focus | Parsing & Execution | Pipes & File Descriptors | fork() , waitpid() , kill() | | Concurrency | Sequential processes | Pipelines | Simulated parallel processes | | IPC | execve , dup2 | Pipes | Signals ( SIGUSR1 , SIGUSR2 ) | | Difficulty Spike | Moderate | High | Extreme |
sem_t *forks; forks = sem_open("/forks", O_CREAT, 0644, number_of_philosophers); // ... later sem_wait(forks); // eat sem_post(forks); // finally sem_close(forks); sem_unlink("/forks"); The Moulinette resets /dev/shm/ . Use unique names like /sem_philo_<pid> to avoid conflicts. Step 3: Simulate Death with alarm() and sigaction A common pattern in Exam 06 is to set a SIGALRM in each child. If time_to_die passes without resetting the alarm, the child kills itself. This is cleaner than having the parent poll every millisecond.
If you can master fork() , sem_wait() , and kill() , you will walk out of 42 Exam 06 not just with a passing grade, but with a true understanding of how operating systems manage processes. And that is the real goal of 42.
void death_handler(int sig)