- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我正在学习 python 中的多处理。我尝试了多处理,在阅读了多处理模块的源代码后,我发现它使用os.fork()
,所以我写了一些代码来测试os.fork()
,但我被卡住了。我的代码如下:
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import os
import time
for i in range(2):
print '**********%d***********' % i
pid = os.fork()
print "Pid %d" % pid
我认为每次打印都会执行两次,但它们会执行三次。我无法理解这是如何工作的?我读了Need to know how fork works?
从这篇文章说它也将被执行两次,所以我被卡住了......
最佳答案
首先,删除 print '******...'
行。它只是让每个人都感到困惑。相反,让我们试试这段代码......
import os
import time
for i in range(2):
print("I'm about to be a dad!")
time.sleep(5)
pid = os.fork()
if pid == 0:
print("I'm {}, a newborn that knows to write to the terminal!".format(os.getpid()))
else:
print("I'm the dad of {}, and he knows to use the terminal!".format(pid))
os.waitpid(pid, 0)
好的,首先,什么是“fork”? Fork 是现代且符合标准的操作系统(M$ Windows 除外:操作系统的笑话几乎是现代且符合标准)的一项功能,它允许进程(又名:“程序” ,其中包括 Python 解释器!)从字面上完全复制自身,有效地创建一个新进程(“程序”的另一个实例)。一旦魔术完成,两个过程都是独立的。更改其中一个中的任何内容不会影响另一个。
负责拼出这个黑暗而古老的咒语的过程被称为父过程。这种对生命本身的不道德憎恶的无灵魂结果被称为子进程。
正如所有人都知道的那样,包括那些并非如此的人,你可以成为那些通过 os.fork()
出卖自己灵魂的精选程序员群体中的一员.该函数执行一个 fork 操作,从而导致第二个进程凭空创建。
现在,这个函数返回什么,或者更重要的是,如何返回?如果你不想发疯,请不要去阅读 Linux 内核的 /kernel/fork.c
文件!一旦内核做了我们知道它必须做的事情,但我们不想接受它,os.fork()
在两个 进程中返回!是的,连调用栈都被复制了!
那么,如果它们是精确的副本,那么如何区分 parent 和 child 呢?简单的。如果 os.fork()
的结果为零,那么您正在 child 中工作。否则,您在父级中工作,返回值是子级的 PID(进程标识符)。反正 child 可以从os.getpid()
得到自己的PID,不是吗?
现在,考虑到这一点,并且在循环中执行 fork()
会导致困惑,这就是发生的情况。我们将原始进程称为“主”进程...
i = 0
, fork 成 child-#1-of-master
i = 1
fork 成 child-#1-of-child-#1-of-masterfor
循环结束,退出for
循环结束,退出i = 1
, fork 成 child-#2-of-master
i = 1
fork 成 child-#1-of-child-#2-of-masterfor
循环结束,退出for
循环结束,退出for
循环结束,退出如您所见,共有 6 个父/子打印来自 4 个独特的进程,产生 6 行输出,类似于...
I'm the dad of 12120, and he knows to use the terminal!
I'm 12120, a newborn that knows to write to the terminal!
I'm the dad of 12121, and he knows to use the terminal!
I'm 12121, a newborn that knows to write to the terminal!
I'm the dad of 12122, and he knows to use the terminal!
I'm 12122, a newborn that knows to write to the terminal!
但这只是任意的,它可以输出这个代替......
I'm 12120, a newborn that knows to write to the terminal!
I'm the dad of 12120, and he knows to use the terminal!
I'm 12121, a newborn that knows to write to the terminal!
I'm the dad of 12121, and he knows to use the terminal!
I'm 12122, a newborn that knows to write to the terminal!
I'm the dad of 12122, and he knows to use the terminal!
或者除此之外的任何东西。操作系统(和你主板的时髦时钟)完全负责进程获取时间片的顺序,所以去 blame on Torvalds (and expect no self-steem when back)如果你不喜欢内核如何管理你的进程;)。
我希望这对你有所启发!
关于Python:os.fork() 是如何工作的?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33560802/
在几个 SO 的问题中,有这些行可以访问代码的父目录,例如os.path.join(os.path.dirname(__file__)) returns nothing和 os.path.join(o
我想用 Python 更改文件模式。 os 模块具有三个功能上看似相同的功能: os.chmod os.fchmod os.lchmod 这三个版本有什么区别? 最佳答案 chmod 用于更改路径指定
考虑: pipe_read, pipe_write = os.pipe() 现在,我想知道两件事: (1) 我有两个线程。如果我保证只有一个正在读取 os.read(pipe_read,n) 而另一个
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visit
让我们以硬盘驱动器/网络接口(interface)为例。它由多个进程共享。现在多个进程可能会向硬盘驱动器发出并发命令来读取数据。当数据可用时,内核如何知道哪个进程的数据已准备好?操作系统和硬盘驱动器之
嗨,我正在尝试编写像这样的原子写入函数...... with tempfile.NamedTemporaryFile(mode= "w", dir= target_directory) as f:
net.Conn接口(interface)提供了 SetTimeout 方法,我应该用 os.Timeout 检查返回的错误.但是我看不到在返回的 os.Error 上调用 os.Timeout 的方
我正在使用 os 模块在我的 Django 项目 settings.py 文件中具有相对路径。变量 SITE_ROOT 设置为 settings.py 文件的当前工作目录,然后用于引用同样位于同一目录
正如我们所知,Windows 接受 "\" 和 "/" 作为分隔符。但是在python中,使用的是"\"。例如,调用 os.path.join("foo","bar"),将返回 'foo\\bar'。
我有以下工作目录:/Users/jordan/Coding/Employer/code_base ,我想要获取绝对路径的文件位于 /Users/jordan/Coding/Employer/code_
在 Python 中,如果路径中包含“~”,我能否确定扩展的用户调用将是绝对路径? 例如,这个表达式是否总是为真? path = '~/.my_app' os.path.expanduser(path
我是 Django 项目的初学者。Django 项目的 settings.py 文件包含这两行: BASE_DIR = os.path.dirname(os.path.dirname(os.path.
我有一个旧 MAC OS 文件存储中的文件集合。我知道集合存在文件名/路径名问题。问题源于我认为在原始操作系统中呈现为破折号的路径中包含一个代码点,但 Windows 与代码点斗争,并且其中一个包含
Ubuntu怎么安装mac os x主题呢?下文小编将为大家分享ubuntu14.04安装mac os x主题教程,安装MAC OS X&
我有一个 Firefox OS 应用程序,我希望在该应用程序之外打开一个链接(该链接指向不同的站点,在应用程序中打开它会使应用程序在没有强制的情况下无法使用)。我怎么做? Related bug re
我想为 Firefox OS 编写我的应用程序.使用什么样的语言(如 Android 的 Java 和 iOS 的 Objective C++)和工具(如 Eclipse、Xcode)? 最佳答案 适
我正在尝试创建一个 Palm OS 应用程序,以每 X 分钟或几小时检查一次网站,并在有数据可用时提供通知。我知道这种事情可以在新的 Palm 上完成——例如,当应用程序不在顶部时,我的 Centro
我需要在 Firefox OS 中显示全屏图像。我有一个具有 qHD 分辨率(960x540 像素)的“峰值”开发预览手机。 如何确保我的应用程序在其他具有不同屏幕分辨率的 firefox-os 设备
我正在尝试在 Firefox OS 中安装一个新的语言环境,但我不确定我是否正确地按照这些步骤操作。 首先,我尝试使用 Mercurial 下载所需的语言环境:它对我不起作用,Mercurial 说访
我有这个shell脚本Test.sh: #! /bin/bash FILE_TO_CHECK="/Users/test/start.txt" EXIT=0 while [ $EXIT -eq 0 ];
我是一名优秀的程序员,十分优秀!