Note: Content is taken from various sources according to the questions asked in interviews. But you can find all at one place.
Operating System
Fork
: The fork call basically makes a duplicate of the current process, identical
in almost every way (not everything is copied over, for example, resource
limits in some implementations but the idea is to create as close a copy as
possible). Vfork
: The basic difference between vfork and fork is that when a new process is
created with vfork(), the parent process is temporarily suspended, and the
child process might borrow the parent's address space. This strange state of
affairs continues until the child process either exits, or calls execve(), at
which point the parent process continues. Exec
:
The exec call is a way to basically replace the entire current
process with a new program. It loads the program into the current process space
and runs it from the entry point. exec() replaces the current process with a
the executable pointed by the function. Control never returns to the original
program unless there is an exec() error.Clone
:
Clone, as fork, creates a new process. Unlike fork, these calls
allow the child process to share parts of its execution context with the
calling process, such as the memory space, the table of file descriptors, and
the table of signal handlers.
Process VS Thread:
Both processes and threads are independent sequences of
execution. The typical difference is that threads (of the same process) run in
a shared memory space, while processes run in separate memory spaces.
The major difference between threads
and processes is:
- Threads share the address space of the process that created it; processes have their own address space.
- Threads have direct access to the data segment of its process; processes have their own copy of the data segment of the parent process.
- Threads can directly communicate with other threads of its process; processes must use interprocess communication to communicate with sibling processes.
- Threads have almost no overhead; processes have considerable overhead.
- New threads are easily created; new processes require duplication of the parent process.
- Threads can exercise considerable control over threads of the same process; processes can only exercise control over child processes.
- Changes to the main thread (cancellation, priority change, etc.) may affect the behavior of the other threads of the process; changes to the parent process does not affect child processes.
.
No comments:
Post a Comment