C fork introduce
来源:互联网 发布:俊平大魔王知乎 编辑:程序博客网 时间:2024/06/05 10:28
fork的作用是创建一个子进程。
摘自《Unix网络编程 卷一》:
fork有两个典型用法。
1)一个进程创建一个自身的副本,这样每个副本都可以在另一个副本执行其他任务的同时处理各自的某个操作。这是网络服务器的典型用法。
2)一个进程想要执行另一个程序。既然创建新进程的唯一办法就是调用fork,该进程于是首先调用fork创建一个自身的副本,然后其中一个副本(通常为子进程)调用exec把自身替换成新的程序。这是诸如shell之类程序的典型用法。
fork()函数会返回两次,分别返回为子进程和父进程,靠返回值来区分,如果返回值为0则当前在子进程里面,若返回值大于0则当前在父进程里面。
看下面例子:
#include <unistd.h>#include <stdio.h>int main() {pid_t fpid; //fpid表示fork函数返回的值,实际是一个int类型int count = 0;//fork之前,只有一个进程在执行这段代码,但在执行这条语句后,就变成两个进程在执行了,这两个进程几乎完全相同//,将要执行的下一条语句都是 if(pid==0)。这两个进程的执行没有先后顺序,靠系统的进程调度策略fpid = fork();if (fpid < 0)printf("error in fork!");else if (fpid == 0) {printf("subprocess, myId: %d\n", getpid()); //getpid:获取进程id,getppid:获取父进程idcount++;} else {printf("parentprocess, subId:%d\n",fpid);printf("parentprocess, myId: %d\n", getpid());count++;}printf("统计结果是: %d\n", count);return 0;}
在下面的例子中,for循环的执行次数为N,那么printf执行的次数为2+4+...+2^N。
#include<stdio.h>#include <unistd.h>int main(){int i=0;int N = 2;for(i=0;i<N;i++){int pid = fork();if(pid==0){printf("sub %d\n",i);}else{printf("par %d\n",i);}}return 1;}
在下面的例子中,一共创建了20个进程,包括main。要首先明白fork()&&fork()||fork()跟( fork() && fork() )|| fork() 是一致的,要了解与或运算的短路原则。
另外,可以将每个fork()分为两个分支来计算。一个分支为>0,另一个分支为==0。画一个树状图,就一目了然了。
#include <stdio.h>#include <unistd.h>int main(int argc, char* argv[]){ fork(); fork() && fork() || fork(); fork(); return 0;}
参考地址:http://blog.csdn.net/jason314/article/details/5640969
0 0
- C fork introduce
- C fork()&&fork()||fork()
- C文件访问 introduce
- introduce
- Introduce
- introduce
- c fork
- linux-fork.c
- C Fork 函数
- linux C fork函数
- linux fork.c
- C fork()函数详解
- c语言:fork函数详解
- linux源代码-fork.c源代码
- c语言:fork函数详解
- Linux C编程--fork()详解
- C小程序 - fork理解
- Linux c fork进程实践
- 2016.7.26 随记
- line-height 和 vertical-align 行高与行对齐精解 (图文)
- Codeforces Round #201 (Div. 1) A. Alice and Bob(数学)
- 公路乘车(完全背包)
- express,使用session进行身份认证
- C fork introduce
- Java多线程面试题
- find 源码剖析
- C++ - PAT - 1053. 住房空置率 (20)
- Session存储方式和配置
- HDU 4432Sum of divisors (进制转换模板)
- 【杭电2141】Can you find it?
- 隐藏标题栏
- HDU 5754 Life Winner Bo (博弈)