fork函数的概念:
在Unix操作系统中,fork函数源于<unistd.h>。其作用是创建一个子进程。
其函数原型为 pid_t fork( void );
· 若调用成功,则会产生一个子进程。因此会返回两个值:子进程内返回0,父进程内返回子进程的ID;
· 若调用失败,则父进程返回-1。
遇到fork最好要画出进程的树状关系图。
父子进程的空间关系:
子进程是父进程的副本,它将获得父进程数据空间的一个一模一样的副本(包括指令,变量值,程序调用栈,环境变量,I/O缓冲区,等等)。注意:子进程持有的是上述存储空间的“副本”,子进程的地址空间是和父进程独立的,父子进程间不共享存储空间。
父子进程的时间关系:
一般不能确定子进程先返回还是父进程先返回。因此不好说fork后面的部分是谁先运行完。但是父进程可以通过调用wait()来阻塞自己,直到子进程的结束才恢复。
程序一:
#include <stdio.h> #include <unistd.h> int main(void) { int i; for(i=0; i<2; i++){ fork(); printf("-"); } return 0; }注意,printf输出不带换行符。关注进程当前IO缓冲区的内容。
问题:输出是什么?
程序二:
#include <stdio.h> #include <sys/types.h> #include <unistd.h> int main(){ pid_t pid1; pid_t pid2; pid1 = fork(); pid2 = fork(); printf("pid1:%d, pid2:%d\n", pid1, pid2); }问题:输出是怎么样的?
程序三:
int main() { return fork()&&fork()||fork(); }
注意,与、或的优先级谁更高?
问题:1.一共产生几个进程 2.返回值为1的概率为多少?程序四:
int main() { fork(); fork() && fork() || fork(); fork(); }问题:创建了多少个子进程?