Why does Unix have fork() but not CreateProcess()? Why does Unix have fork() but not CreateProcess()? unix unix

Why does Unix have fork() but not CreateProcess()?


The fork() call is sufficient. It is also more flexible; it allows you to things like adjust the I/O redirection in the child process, rather than complicating the system call to create the process. With SUID or SGID programs, it allows the child to lose its elevated privileges before executing the other process.

If you want a complex way to create a process, lookup the posix_spawn() function.

#include <spawn.h>int posix_spawn(pid_t *restrict pid, const char *restrict path,        const posix_spawn_file_actions_t *file_actions,        const posix_spawnattr_t *restrict attrp,        char *const argv[restrict], char *const envp[restrict]);int posix_spawnp(pid_t *restrict pid, const char *restrict file,          const posix_spawn_file_actions_t *file_actions,       const posix_spawnattr_t *restrict attrp,       char *const argv[restrict], char *const envp[restrict]);

The difference is the posix_spawnp() does a search on PATH for the executable.

There is a whole set of other functions for handling posix_spawn_file_actions_t and posix_spawnattr_t types (follow the 'See Also' links at the bottom of the referenced man page).

This is quite a bit more like CreateProcess() on Windows. For the most part, though, using fork() followed shortly by exec() is simpler.


I don't understand what you mean. The child process code will be written by me, so what is the difference between writing if (fork() == 0) and putting this code in the beginning of child's main()?

Very often, the code you execute is not written by you, so you can't modify what happens in the beginning of the child's process. Think of a shell; if the only programs you run from the shell are those you've written, life is going to be very impoverished.

Quite often, the code you execute will be called from many different places. In particular, think of a shell and a program that will sometimes be executed in a pipeline and sometimes executed without pipes. The called program cannot tell what I/O redirections and fixups it should do; the calling program knows.

If the calling program is running with elevated privileges (SUID or SGID privileges), it is normal to want to turn those 'off' before running another program. Relying on the other program to know what to do is ... foolish.


UNIX-like operating systems (at least newer Linux and BSD kernels) generally have a very efficient fork implementation -- it is "so cheap" that there are "threaded" implementations based upon it in some languages.

In the end the forkexec function is ~n -- for some small value of n -- lines of application code.

I sure wish windows had such a useful ForkProcess :(

Happy coding.


A cnicutar mentioned, Copy-On-Write (COW) is one strategy used.


There is a function that is equivalent to forkexec - system

http://www.tutorialspoint.com/c_standard_library/c_function_system.htm

#include <stdio.h>#include <string.h>int main (){  char command[50];  strcpy( command, "ls -l" );  system(command);  return(0);}