麦子学院 2017-08-05 20:22
Python中使用os.fork() 如何创建子进程?
回复:0 查看:2854
本文和大家分享的主要是python中使用os.fork() 创建子进程相关内容,一起来看看吧,希望对大家
学习python
有所帮助。
Linux 操作系统提供了一个 fork() 函数用来创建子进程,这个函数很特殊,调用一次,返回两次,因为操作系统是将当前的进程(父进程)复制了一份(子进程),然后分别在父进程和子进程内返回。子进程永远返回0,而父进程返回子进程的 PID。我们可以通过判断返回值是不是 0 来判断当前是在父进程还是子进程中执行。
在 Python 中同样提供了 fork() 函数,此函数位于 os 模块下。
下面是一个例子
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())
运行结果如下:
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 模块来创建子进程。
来源:kongxx的专栏
Linux 操作系统提供了一个 fork() 函数用来创建子进程,这个函数很特殊,调用一次,返回两次,因为操作系统是将当前的进程(父进程)复制了一份(子进程),然后分别在父进程和子进程内返回。子进程永远返回0,而父进程返回子进程的 PID。我们可以通过判断返回值是不是 0 来判断当前是在父进程还是子进程中执行。
在 Python 中同样提供了 fork() 函数,此函数位于 os 模块下。
下面是一个例子
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())
运行结果如下:
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 模块来创建子进程。
来源:kongxx的专栏