fork函数的用法总结

来源:互联网 发布:域名提供商查询 编辑:程序博客网 时间:2024/05/16 10:35

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

原创粉丝点击