1.示例代码
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
int main(void) {
/*此时只有一个进程*/
pid_t child_pid;
/*此时已经有两个进程*/
child_pid = fork();
/**
* 若子线程创建失败fork()函数返回-1
* 若子线程创建成功fork()函数返回0
*/
if(child_pid == -1){
printf("Create Process Failed !\n");
}else if(child_pid == 0){
printf("Child Process with ID %d !\n",getpid());//此时的getpid()输出的是执行该句话的进程, 也就是fork()创建的子进程的pid
}else{
//此时的getpid()输出的是主进程的pid, chid_pid对应的是主线程创建的子线程的pid
printf("Parent Process with ID %d , Child Process with ID %d!\n",getpid(),child_pid);
}
return 0;
}
输出结果
Parent Process with ID 2911 , Child Process with ID 2916!
Child Process with ID 2916 !
2.理解分析
1.在chilid_pid = fork() 之前,只有一个线程在执行,但在这条这条语句执行之后,就变成了连个进程在执行了,这两个进程的共享代码段是fork()函数之后的代码, 两个进程都将会分别执行fork()函数之后代码,将要执行的下一句代码都是if(child_pid == -1)。
2.两个进程中,原来就存在的那个进程被称为“父进程”,新出现的那个进程被称为“子进程”,父子进程之间的区别在于进程标识符(PID)不同。
3.
child_pid = fork();
若子线程创建失败fork()函数返回-1,child_pid =-1;
若子线程创建成功fork()函数返回0,child_pid =0.
4.若没有两个线程同时执行则不可能有上述的输出结果