EMC的一个笔试题目

 同学参加了EMC的笔试回来,说了一个EMC的一个笔试题目,他没有答上来,就问我。我感觉很有意思,就拿出来分析一下。

======================================
int main(int argc, char* argv[])
{
   fork();
   fork() && fork() || fork();
   fork();
}

不算main这个进程自身,到底创建了多少个进程啊?
======================================

为了解答这个问题,我们先作一下弊,先用程序验证一下,到此有多少个进程。
int main(int argc, char* argv[])
{
   fork();
   fork() && fork() || fork();
   fork();
  
   printf("+/n");
}

在代码最后加一个printf语句,看最后有多少行,就说明有多少进程。
答案是总共20个进程,出去main进程,还有19个进程。

我们再来仔细分析一下,为什么是还有19个进程。

p, li { white-space: pre-wrap; }

第一个fork和最后一个fork肯定是会执行的。

主要在中间3个fork上,可以画一个图进行描述。

这里就需要注意&&和||运算符。

 

A&&B,如果A=0,就没有必要继续执行了;A非0,就需要继续执行&&B。

A||B,如果A非0,就没有必要继续执行了,A=0,就需要继续执行||B。

 

fork()对于父进程和子进程的返回值是不同的,按照上面的A&&B和A||B的分支进行画图,可以得出5个分支。

 

加上前面的fork和最后的fork,总共4*5=20个进程,除去main主进程,就是19个进程了。

 

转自:http://blog.chinaunix.net/u/12592/showart.php?id=2084111

posted on 2009-11-04 10:33  SunBo 阅读( ...) 评论( ...) 编辑 收藏

转载于:https://www.cnblogs.com/sunyubo/archive/2009/11/04/2708299.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值