python os.fork() 循环输出
2016-04-06 17:04
603 查看
先看下面这段代码:
猜测一下,会输出几行Hello。
答案是:
Hello
Hello
Hello
Hello
Hello
Hello
6行!为什么呢?
首先,你要明白os.fork()创建的子进程会接着下一行代码继续执行,它有返回值,返回值可以为0表示子进程或者大于0表示父进程pid,os.getpid()返回的是当前进程的pid,那么我们再改改输出来看得更直观一些吧:
输出是这样的:
Hello 0 9760 9761
Hello 0 9761 0
Hello 1 9760 9762
Hello 1 9762 0
Hello 1 9761 9763
Hello 1 9763 0
这就很容易解释了:
第一轮循环,父进程创建了一个子进程P1然后打印,子进程P1接着下面的代码运行,打印。之后进入第二轮循环;
第二轮循环,父进程创建了一个子进程P2然后打印,子进程P2接着下面的代码运行,打印。子进程P1再创建了一个子进程P12然后打印,子进程P12接着下面的代码运行,打印。之后循环结束,共打印六次。
如果进行3轮循环打印多少次呢,答案是14次,读者可以自行验证一下。
水平有限,如有错误欢迎指正!
import os def main(): for i in range(0, 2): os.fork() print 'Hello' if __name__ == '__main__': main()
猜测一下,会输出几行Hello。
答案是:
Hello
Hello
Hello
Hello
Hello
Hello
6行!为什么呢?
首先,你要明白os.fork()创建的子进程会接着下一行代码继续执行,它有返回值,返回值可以为0表示子进程或者大于0表示父进程pid,os.getpid()返回的是当前进程的pid,那么我们再改改输出来看得更直观一些吧:
import os def main(): for i in range(0, 2): pid = os.fork() print "Hello", i, os.getpid(), pid if __name__ == '__main__': main()
输出是这样的:
Hello 0 9760 9761
Hello 0 9761 0
Hello 1 9760 9762
Hello 1 9762 0
Hello 1 9761 9763
Hello 1 9763 0
这就很容易解释了:
第一轮循环,父进程创建了一个子进程P1然后打印,子进程P1接着下面的代码运行,打印。之后进入第二轮循环;
第二轮循环,父进程创建了一个子进程P2然后打印,子进程P2接着下面的代码运行,打印。子进程P1再创建了一个子进程P12然后打印,子进程P12接着下面的代码运行,打印。之后循环结束,共打印六次。
如果进行3轮循环打印多少次呢,答案是14次,读者可以自行验证一下。
水平有限,如有错误欢迎指正!
相关文章推荐
- Leetcode 22. Generate Parentheses(python)
- python2.7和3.0区别
- 关于Python编码,超诡异的,我也是醉了
- Python条件语句
- Python判断Unicode字符串类型
- 几种排序算法分析及python实现
- 排序(1) 初级排序
- python 接口自动化测试(四)
- Python一日一练07----冒泡排序
- python 读取图片数据
- Python-解决pip安装库时UnicodeDecodeError的错误
- python用post方法,向solr进行删除,更新,插入操作
- Python3:range生成数列用法
- python 用list,dic实现switch功能的一个奇葩现象
- mongo更新与删除集合中的字段python
- python 异常 try-except句型
- python开发环境搭建
- Caffe学习系列(13):数据可视化环境(python接口)配置
- python多进程共享变量
- Python Twisted系列教程22:结束