in reply to Re^2: Please Explain the Parallel::ForkManager Idiom my $pid = $pm->start and next;
in thread Please Explain the Parallel::ForkManager Idiom my $pid = $pm->start and next;

Here is a forking program expressed as a tree (this is parent)

The child process execution is

When the fork call is reached, the parent process creates a child process (clone), and returns a pid for the new child process

The child process doesn't clone/create a new child process (only parent does that), and fork returns zero

After that the two processes are identical, and each of them continues execution from the point of fork ... they both execute code after fork

The child doesn't start from beginning to execute code before fork (its not a new process, its a clone of the parent)

 

When you run the program here is the execution order as a tree

Or the same in table tree form :) the parent process is started and it runs
code before fork
fork call (I parent clone child here) I child gets 0 and I run in parallel
code after fork code after fork

  • Comment on Re^3: Please Explain the Parallel::ForkManager Idiom my $pid = $pm->start and next;