fork()
The fork() function creates a new child process by sharing the same code as the calling process and duplicating the calling process's data to give the child process an exact copy. Most process resources are inherited.
- process ID
- parent process ID
- file locks
- pending signals and alarms
- timers
- to create a new instance of the current execution environment
- to create a new process running a different program
When creating a new thread, common data is placed in an explicitly created shared memory region. Prior to the POSIX thread standard, this was the only way to accomplish this. With POSIX threads, this use of fork() is better accomplished by creating threads within a single process using pthread_create().
When creating a new process running a different program, the call to fork() is soon followed by a call to one of the exec*() functions. This too is better accomplished by a single call to the posix_spawn() function or the QNX OS spawn() function, both of which combine both operations with far greater efficiency.
Since QNX OS provides better POSIX solutions than using fork(), its use is probably best suited for porting existing code and for writing portable code that must run on a UNIX system that doesn't support the POSIX pthread_create() or posix_spawn() API.
Using fork() in a multithreaded processin the
Processes and Threadschapter of Getting Started with the QNX OS.
