I talked about zombie progression in the last article, but I’m going to share with you another state.
An orphan
What is the orphan process? When a child process is in the execution, its parent is out of the race, then the child process to exit information has not been the parent process to receive, if the child’s exit information is not received by other processes, so that the child will become a zombie process, so the orphan process could create a zombie process. Therefore, the child process must be adopted by another process. If the adopted process is process 1, its exit message will be received by process 1. If the parent exits, does the parent become a zombie? No, because the parent’s parent is bash, and the parent’s exit message is received by bash, which we don’t see.
Let’s revisit zombie progression and orphan progression:
Zombie progression:
A process uses fork to create a child. If the child exits and the parent does not call wait or WaitPID to obtain the child’s state, the child’s process descriptor remains in the system.
This process is called rigor mortis.
Orphan processes: When a parent exits and one or more of its children are still running, those children become orphan processes. Orphan processes are adopted by the init process (process number 1), which collects state for them.
What is the harm of the orphan process?
An orphan process is a process that has no parent, so the onus falls on the init process, which acts like a civil bureau and takes care of the orphan process. Whenever an orphan process is present, the kernel sets the parent of the orphan process to init, and the init process loops to wait() for its exiting child. Thus, when an orphan process comes to a dismal end to its life cycle, the init process takes care of all its aftermath on behalf of the party and the government. So the orphan process doesn’t do any harm.
How do I create an orphan process?
Create an orphan process (just let the parent exit and the child continue)
#include<stdio.h> #include<unistd.h> #include<stdlib.h> int main() {pid_t pid = fork(); If (pid == 0) {printf("child pid=%d ppid=%d\n", getpid(), getppId ()); sleep(3); } } else if (pid > 0) { //parent printf("parent pid=%d ppid=%d\n", getpid(), getppid()); sleep(5); exit(1); } else { perror("fork()"); } return 0; }Copy the code
Open a monitor, since you also need to see the id of the parent process
Execution result :(5 seconds later, the parent process of the child process changes to process 1, indicating that the child process is adopted by process 1 after the parent process exits.)