python什么时候用多进程编程


本文摘自php中文网,作者(*-*)浩,侵删。

在并发编程的时候,多线程和多进程是经常会被使用的两种模式(此外还有协程等)。由于 CPython 的 GIL 限制(Jython 和 IronPython 没有 GIL,PyPy 在尝试去掉 GIL),只有获取了 GIL 的线程才能使用 CPU,所以除了需要处理一些可能会阻塞的 IO(读写文件、访问网络等)之外,基本没人会去使用 CPython 的多线程。因此,本文就来说说更有用的 Python 多进程编程。

注:推荐学习:Python视频教程)

本文描述的环境为 Linux 操作系统(也适用于大部分 POSIX 系统)下的 CPython,可能不适用于 Windows操作系统或其他的Python 实现。

为了避免歧义,下文用「主进程」或「当前进程」表示创建子进程的那个进程,而不使用「父进程」,除非明确指明了「xx 的父进程」。

与多线程编程时需要传递一个 callable 对象不同的是,多进程编程的时候,是将主进程复制到子进程,并不能直接要求子进程执行某个 callable 对象。

在 POSIX 系统中,这个复制操作是由 clone() 和 fork() 系统调用来完成的,一般主要使用后者。
如果 fork() 执行成功的话,会分别在主进程和子进程中返回子进程的 PID 和 0,然后执行代码就开始不同了。如果失败的话(内存不够、PID 达到上限等),子进程就不会创建,主进程会返回 -1,errno 会被设置为对应的错误码。
在 CPython 的实现中,os.fork() 主要是对 fork() 函数的封装,差别在于失败时抛出 OSError,该异常的 errno 属性是对应的错误码。

因此,多进程的 Python 代码大致会长成这样:

1

2

3

4

5

6

7

8

9

10

import os

 

try:

    pid = os.fork()

    if pid == 0:  # 子进程

        # 子进程的代码

    else:  # 主进程

        # 主进程的代码

except OSError:

    # 主进程处理 fork 失败的代码

更多Python相关技术文章,请访问Python教程栏目进行学习!

以上就是python什么时候用多进程编程的详细内容,更多文章请关注木庄网络博客!!

相关阅读 >>

Python笔试题之设计“跳一跳”小游戏计分器

Python语言是一种什么类型

Python如何实现一个登陆验证(文件验证)

如何用字典的值(key)对字典进行排序

Python的解释器是什么?

安卓app可以用Python写吗

Python怎么取余数

了解Python的collections.counter类型

Python中排序算法的实现方法总结(代码)

安装完Python怎么打开

更多相关阅读请进入《Python》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...