您的位置:首页 > 编程语言 > Python开发

python os.fork() 循环输出

2016-04-06 17:04 603 查看
 先看下面这段代码:
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次,读者可以自行验证一下。

    水平有限,如有错误欢迎指正!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: