Sprawdź najpierw co robi funkcja fork() i co zwraca w procesie macierzystym, a co w procesie potomnym. Dwie funkcje fork() następujące po sobie stworzą trzy procesy działające współbieżnie. Pierwszy if wykona się w procesie macierzystym, ponieważ otrzyma PID potomnego procesu. Będą w tym miejscu dwa procesy, gdzie tylko jeden(macierzysty) przejdzie do drugiego if'a. Potomny od razu wypisze print(b), stąd pierwsze pojawi się -20. Drugi if się wykona tylko w procesie potomnym, ponieważ negacja z zera wynosi 1, więc prawdę. Macierzysty, więc może przejść od razu do print(b). Drugi fork stworzy dwa procesy z których tylko jeden wypisze a, a następnie b. Program zwraca u Ciebie -20, 10, -20, -20, ale równie dobrze mógłby zwracać -20, -20, 10, -20.
Wynik zależy od systemu operacyjnego, od sposobu przeplotu tych procesów. Istnieje prawdopodobieństwo, że różnych wyników może być 24, bo nie wiadomo jak system operacyjny je poukłada.
Mam nadzieję, że ten kod pomoże w zrozumieniu co i jak:
#include <stdio.h>
#include <unistd.h>
void print(int a) {
printf("%d\n", a);
}
int main(void) {
// your code goes here
int pid;
int a = 10, b=-20;
if(pid = fork()) {
printf("%s", "Pierwszy ");
print(pid);
if(!(pid = fork())) {
printf("%s", "Drugi ");
print(pid);
print(a);
}
}
printf("%s", "Trzeci ");
print(pid);
print(b);
return 0;
}