fork
函数原型:
pid_t fork();
返回值:
若成功调用一次则返回两个值:
向子进程返回0,
向父进程返回子进程ID(大于0);否则,出错返回-1
函数说明:
一个现有进程可以调用fork函数创建一个新进程。由fork创建的新进程被称为子进程(child process)。
fork函数被调用一次但返回两次。两次返回的唯一区别是子进程中返回0值而父进程中返回子进程ID。
子进程是父进程的副本,它将获得父进程数据空间、堆、栈等资源的副本。
子进程持有的是上述存储空间的“副本”,这意味着父子进程间不共享这些存储空间。
UNIX将复制父进程的地址空间内容给子进程,因此,子进程有了独立的地址空间。在不同的UNIX (Like)系统下,我们无法确定fork之后是子进程先运行还是父进程先运行,这依赖于系统的实现。
解释来源于fork
例题
int main(int argc,char* argv){
fork();
fork() && fork() || fork();
fork();
}
问该例程创建了多少子进程?(不包含main函数产生的进程)
分析
分析该例程创建多少进程,我们主要要熟练掌握知道的知识是逻辑运算符的优先级及短路规则,现假设有以下语句:
a && b || c;
1.a为真,判断b是否为真
b为真,不判断c
b为假,判断c
2.a为假,短路b,直接判断c
这道题完成图解如下,fork( )表示该语句被短路,不执行:
所以,答案是19