简单分析Python中用fork()函数生成的子进程

作者:goldensun 时间:2021-11-24 02:48:02 

python的os module中有fork()函数用于生成子进程,生成的子进程是父进程的镜像,但是它们有各自的地址空间,子进程复制一份父进程内存给自己,两个进程之 间的执行是相互独立的,其执行顺序可以是不确定的、随机的、不可预测的,这点与多线程的执行顺序相似。 


import os
def child():
 print 'A new child:', os.getpid()
 print 'Parent id is:', os.getppid()
 os._exit(0)
def parent():
 while True:
   newpid=os.fork()
   print newpid
   if newpid==0:
     child()
   else:
     pids=(os.getpid(),newpid)
     print "parent:%d,child:%d"%pids
     print "parent parent:",os.getppid()    
   if raw_input()=='q':
     break
parent()

    在我们加载了os模块之后,我们parent函数中fork()函数生成了一个子进程,返回值newpid有两个,一个为0,用以表示子进程,一个是大于 0的整数,用以表示父进程,这个常数正是子进程的pid. 通过print语句我们可以清晰看到两个返回值。如果fork()返回值是一个负值,则表明子进程生成不成功(这个简单程序中没有考虑这种情况)。如果 newpid==0,则表明我们进入到了子进程,也就是child()函数中,在子进程中我们输出了自己的id和父进程的id。如果进入了else语句, 则表明newpid>0,我们进入到父进程中,在父进程中os.getpid()得到自己的id,fork()返回值newpid表示了子进程的id,同时我们输出了父进程的父进程的id. 通过实验我们可以看到if和else语句的执行顺序是不确定的,子、父进程的执行顺序由操作系统的调度算法来决定。

标签:Python
0
投稿

猜你喜欢

  • Vue实现购物车功能

    2024-04-30 10:26:21
  • pytorch加载预训练模型与自己模型不匹配的解决方案

    2023-06-17 14:22:24
  • Python实现文件按照日期命名的方法

    2022-10-25 19:40:09
  • 关于Python的Thread线程模块详解

    2022-12-20 02:48:16
  • python pandas dataframe 去重函数的具体使用

    2023-10-15 00:56:36
  • 如何在SQL Server数据库中加密数据

    2008-12-18 14:27:00
  • 兼容firefox的给每一个onClick再附加一个事件

    2023-08-24 18:29:47
  • ASP中如何判断字符串中是否包数字

    2008-07-21 12:04:00
  • javascript时间戳和日期字符串相互转换代码(超简单)

    2024-04-30 10:09:20
  • 利用Python操作消息队列RabbitMQ的方法教程

    2022-12-11 21:52:16
  • 使用graphics.py实现2048小游戏

    2021-03-20 01:47:19
  • MySQL内建复制功能来优化可用性

    2010-10-25 20:20:00
  • Oracle中PL/SQL的块与表达式

    2024-01-28 21:30:34
  • python中OrderedDict的使用方法详解

    2023-08-26 14:00:40
  • php测试程序运行速度和页面执行速度的代码

    2023-06-14 07:49:18
  • Django CBV类的用法详解

    2022-11-24 20:33:43
  • mysql 5.7 docker 主从复制架构搭建教程

    2024-01-21 22:46:03
  • IE7的web标准之道 Ⅱ

    2008-08-13 12:50:00
  • Python爬虫之xlml解析库(全面了解)

    2023-03-30 21:16:17
  • Python文件和流(实例讲解)

    2023-08-02 19:11:45
  • asp之家 网络编程 m.aspxhome.com