Python进程专题1:fork():创建子进程、getpid()、getppid()

上一篇文章:
Python进程专题总览篇

下一篇文章:
Python进程专题2:multiprocessing创建进程

该方法只能在unix/Linux/Mac上运行,windows不可以运行。

程序执行到fork()时,操作系统会创建一个新进程(子进程),并把父进程的所有信息赋值到子进程中。

这个方法很特殊,会有两次返回,分别在子进程和父进程返回一次,子进程永远返回0,父进程返回进程的id.

getpid():返回当前进程的id

getppid():返回当前进程父进程的id。

实例:

import os
id=os.fork()
index=0
if id<0:
    print("子进程创建失败了")
elif id==0:
    index+=1
    print("我是子进程(%d),我的父进程是:%d,index=%d"%(os.getpid(),os.getppid(),index))
else:
    index += 1
    print("我是父进程:%d,我的子进程是:%d,index=%d"%(os.getpid(),id,index))

结果:

我是父进程:9735,我的子进程是:9736,index=1
我是子进程(9736),我的父进程是:9735,index=1

从上面实例也可以看出:每个进程的所有数据(包括全局变量)都各持一份,互不影响。

多次fork()可发现:父子进程执行顺序没有规律,完全取决于操作系统的调度算法。

    原文作者:Mark
    原文地址: https://segmentfault.com/a/1190000016242923
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞