EMC的一个笔试题目
2009-11-04 10:33
253 查看
同学参加了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
======================================
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
相关文章推荐
- EMC的一个笔试题目
- EMC的一个笔试题目
- 咪咕笔试题目:统计键盘写入一个字符串的按键点击次数
- C++语言笔试题目写一个函数计算当参数为n(n很大)时的值 1-2+3-4+5-6+7......+n&字符指针、浮点数指针、以及函数指针占用的内存等
- 问对于一个给定的n,怎样才能用最少的步骤将它变到1。--淘宝笔试题目
- 一个公司的笔试题目
- 《课程格子》的一个笔试题目
- 阿里巴巴校招2017前端笔试题目 -- 原生js/html5 实现一个路由
- [笔试题目]使用Stringbuffer无 参的构造函数创建 一个对象时,默认的初始容量是多少? 如果长度不够使用了,自动增长多少倍?
- 中兴的一个笔试题目,,,short s1=1;s1=s1+1; 有什么错误,,,
- 一个笔试题目
- 百度前端笔试题目--css 实现一个带尖角的正方形
- 笔试题目---描述在浏览器中敲入一个网址并按下回车后所发生的事情
- EMC校招笔试题目
- 笔试题目1:写一个函数,返回一个数组中所有元素被第一个元素除的结果
- 看了SAP的笔试题目,顺手写一个单件模式
- (笔试中的题目)一个已经排序好的数组找到两个数字相加等于一个给定的数
- 据说是一个著名公司的笔试题目
- 明源笔试题目--将一个正整数分解质因数
- 一道笔试题 题目是这样的:判断一个小于1000的正整数是否为素数。