首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Python 使用 os.fork() 创建子进程

Python 使用 os.fork() 创建子进程

作者头像
kongxx
发布2018-05-14 12:14:52
发布2018-05-14 12:14:52
2K00
代码可运行
举报
运行总次数:0
代码可运行

Linux 操作系统提供了一个 fork() 函数用来创建子进程,这个函数很特殊,调用一次,返回两次,因为操作系统是将当前的进程(父进程)复制了一份(子进程),然后分别在父进程和子进程内返回。子进程永远返回0,而父进程返回子进程的 PID。我们可以通过判断返回值是不是 0 来判断当前是在父进程还是子进程中执行。

在 Python 中同样提供了 fork() 函数,此函数位于 os 模块下。

下面是一个例子

代码语言:javascript
代码运行次数:0
运行
复制
import os
import time

print "Before fork process pid=%s, ppid=%s" % (os.getpid(), os.getppid())

pid = os.fork()
if pid == 0:
    print "I am child process pid=%s, ppid=%s" % (os.getpid(), os.getppid())
    time.sleep(5)
else:
    print "I am parent process pid=%s, ppid=%s" % (os.getpid(), os.getppid())
    time.sleep(5)

# 下面的内容会被打印两次,一次是在父进程中,一次是在子进程中。
print "After fork process pid=%s, ppid=%s" % (os.getpid(), os.getppid())

运行结果如下:

代码语言:javascript
代码运行次数:0
运行
复制
Before fork process pid=18595, ppid=25925
I am parent process pid=18595, ppid=25925
I am child process pid=18596, ppid=18595
After fork process pid=18595, ppid=25925
After fork process pid=18596, ppid=18595

最后,由于 fork() 是 Linux 上的概念,所以如果要跨平台,最好还是使用 subprocess 模块来创建子进程。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017.08.01 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档