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();
}
问题:创建了多少个子进程?