【Python从入门到精通】(二十五)Python多进程的使用

【Python从入门到精通】(二十五)Python多进程的使用

您好,我是码农飞哥,感谢您阅读本文,欢迎一键三连哦
本篇重点介绍Python多进程的使用,读者朋友们可以将多进程和多线程两者做一个对比学习。
干货满满,建议收藏,需要用到时常看看。 小伙伴们如有问题及需要,欢迎踊跃留言哦~ ~ ~。

前言

前面我们介绍了多线程的使用,这篇文章将来学习多进程的使用。

进程的创建

Python的multiprocessing模块提供了Process类,该类可用来在各平台下创建新进程。其构造函数是:

__init__(self, group=None, target=None, name=None, args=(), kwargs={})

其中,各个参数的含义如下:

  1. group: 该参数未实现,不需要传参

  2. target:为新建进程指定执行任务,也就是指定一个函数

  3. args:以元组的方式,为target指定的方法传递参数,如果传入的是元组中有多个参数的话则传入方式是(arg1,arg2,....argn,)

  4. kwargs:以字典的方法,为target指定的方法传递参数。

  5. name: 为新建进程设置名称

一些常用方法介绍

  1. start() 方法用于启动进程

  2. run() 方法用于运行所要执行的任务

  3. is_alive() 方法用于判断当前进程是否还活着

  4. getPid() 方法用于获取进程的ID号。

1.直接创建Process类的实例对象,由此就可以创建一个新的进程;

这个就类似于直接创建实例化线程Thread类

from multiprocessing import Process
import os
# 定义要调用的方法
def async_fun(name, add):
    for arc in add:
        print(name + str(os.getpid()) + " " + arc)

if __name__ == '__main__':
    my_tuple = ("码农飞哥", "今天是宅家的一天", "30岁了还没对象焦虑呀")

    # 创建进程
    process = Process(target=async_fun, args=("子进程", my_tuple))
    # 启动子进程
    process.start()
    # 启动主进程
    async_fun("主进程", my_tuple)

运行结果是:

主进程11610 码农飞哥
主进程11610 今天是宅家的一天
主进程11610 30岁了还没对象焦虑呀
子进程11612 码农飞哥
子进程11612 今天是宅家的一天
子进程11612 30岁了还没对象焦虑呀

这里需要注意的一点是,必须要将代码放在if __name__ == '__main__': 代码块中。通过os.getpid()方法来获取进程号。

2.通过继承Process类的子类,创建实例对象,也可以创建新的进程。

第二种方式就是通过继承Process类的子类,创建实例对象,也可以创建新的进程,不过这种方式需要重写父类的run()方法。这种方法就类似于直接继承Thread类创建线程。

import multiprocessing
import os

# 定义要调用的方法
def async_fun(name, add):
    for arc in add:
        print(name + str(os.getpid()) + " " + arc)

class MyProcess(multiprocessing.Process):
    def __init__(self, name, add):
        multiprocessing.Process.__init__(self)
        self.add = add
        self.name = name
        # 重写run()方法

    def run(self):
        async_fun(self.name, self.add)

if __name__ == '__main__':
    my_tuple = ("码农飞哥", "今天是宅家的一天", "宅家也不能虚度")
    myprocess = MyProcess("子进程", my_tuple)
    myprocess.start()
    # 主进程
    async_fun("主进程", my_tuple)

运行结果同上。
这里还是推荐使用第一种方法创建进程,因为这种方式创建进程比较简洁

进程池的使用

由于创建进程对系统的开销比较大。所以,所以在实际开发中一般都会使用进程池来创建进程。进程池的使用与线程池的使用也是有神似的地方。同样的在multiprocessing模块中提供了Pool函数来创建进程池。

import os
from multiprocessing import Pool
import time

# 定义要调用的方法
def async_fun(add):
    time.sleep(1)
    print("进程号:" + str(os.getpid()) + " " + add)

if __name__ == '__main__':
    add = "码农飞哥,今天是宅家的一天,30岁了还没对象焦虑呀"
    # 创建包含4个进程的进程池
    pool = Pool(processes=4)
    # 提交action
    pool.apply_async(func=async_fun, args=(add,))
    pool.apply_async(func=async_fun, args=("加油加油",))
    pool.close()
    pool.join()

运行结果是:

进程号:11658 码农飞哥,今天是宅家的一天,30岁了还没对象焦虑呀
进程号:11659 加油加油

同样的进程池也可以通过with语句来创建

from multiprocessing import Pool
import os
import time

def async_add(max):
    time.sleep(1)
    print("进程号:" + str(os.getpid()) + "最大值是" + str(max))

if __name__ == '__main__':
    with Pool(processes=4) as pool:
        # 使用线程池执行max计算
        results = pool.map(async_add, (20, 30, 40, 50))

运行结果是:

进程号:11726最大值是20
进程号:11725最大值是30
进程号:11727最大值是40
进程号:11728最大值是50

多进程和多线程的优缺点对比

多进程的优点就是稳定性好,一个子进程崩溃了,不会影响主进程以及其余子进程,各个子进程各用一套独立的内存空间。多线程的优点就是效率高,适用于批处理等功能。
多进程的缺点就是创建进程的代价非常大,因为操作系统要给每个进程分配固定的资源,并且操作系统对进程的总数会有一定的限制,若进程过多,操作系统调度都会存在问题,会造成假死状况。

总结

本文详细介绍了Python多进程的使用。

Python知识图谱

为了更好帮助更多的小伙伴对Python从入门到精通,我从CSDN官方那边搞来了一套 《Python全栈知识图谱》,尺寸 870mm x 560mm,展开后有一张办公桌大小,也可以折叠成一本书的尺寸,有兴趣的小伙伴可以了解一下------扫描下图中的二维码即可购买。

我本人也已经用上了,感觉非常好用。图谱桌上放,知识心中留。

我是码农飞哥,再次感谢您读完本文
全网同名【码农飞哥】。不积跬步,无以至千里,享受分享的快乐
我是码农飞哥,再次感谢您读完本文

(0)

相关推荐

  • 用Python创建你第一个GIS程序[5]:多进程解决线程堵塞

    前言:在上一章中,我们将前后端连接起来,算是真正把程序给创建了出来.但是存在一个问题:当你点击"运行"按钮运行程序后,再用鼠标点击拖动 GUI 界面就会卡死... 线程堵塞 当点击 ...

  • (1条消息) Python 多进程 multiprocessing.Pool类详解

    multiprocessing模块 multiprocessing包是Python中的多进程管理包.它与 threading.Thread类似,可以利用multiprocessing.Process对 ...

  • 一篇文章带你解析Python进程

    来源|本文经授权转载自Python爬虫与数据挖掘 前言 进程,一个新鲜的字眼,可能有些人并不了解,它是系统某个运行程序的载体,这个程序可以有单个或者多个进程,一般来说,进程是通过系统CPU 内核数来分 ...

  • 第52天:Python multiprocessing 模块

    本节主要介绍 multiprocessing 多进程模块,由于 threading 多线程模块无法充分利用电脑的多核优势,而在实际开发中会对系统性能有较高的要求,就需要使用多进程来充分利用多核 cpu ...

  • CS5 从入门到精通教程板书(二十五)

    CS5 从入门到精通教程板书(二十五) 第六十四节  形状图层 这是一个形状图层,可以看出它是图层样式和图层蒙版的结合.形状图层的位置,如下图: 由此可以看出这两个工具都是和路径有关的,两个图左方用红 ...

  • python+opencv图像处理(二十五)

    图像锐化(image sharpening)可以增强图像的边缘部分. 1.梯度法 图像锐化的方法很多,梯度法是其中较常用的一种. 梯度是函数变化的一种度量,是一阶导数的二维等效形式,利用梯度的离散逼近 ...

  • PreScan快速入门到精通第十二讲之PreScan导入OpenStreet Map格式地图

    目的: 作为手动创建整个道路网络的替代方案,PreScan允许用户导入一个道路网络. 从外部开放街道地图(.OSM)文件中导出网络.这可以通过选择导出的XML选项来完成. 当导入OSM文件时,在此文件 ...

  • 周易入门:无妄(卦二十五)

    无妄(卦二十五) --"思无邪"的做人准则 [原文] (震下乾上)无妄(1):元亨,利贞.其匪正,有眚.不利有攸 往. 初九:无妄往,吉. 六二:不耕,获;不菑,畲(3).则利有攸 ...

  • PreScan快速入门到精通第二十二讲驾驶员模型之路径跟踪

    22.1 PreScan路径跟踪路径跟踪驾驶员模型是一个Simulink子模块,它将轨迹(路径+速度曲线)转化为车辆动力学模型的转向角输入.油门.刹车和初始速度也被控制,但这些与轨迹速度曲线无关.为了 ...

  • 晨之风随笔《纪念处女作发表二十五周年》

    昨天晚上,远在北京的弟弟在聊天时,发我一张手机图片.说是在收拾东西时,无意中发现了我过去的一篇文章.文章是打印的,字迹已经不太清晰了,题目是<畅享金秋>.对这篇还谈不上文章的文章,我几乎没 ...

  • 十万个冷知识(四百二十五)

    中国人的脸,在菲律宾是土豪的象征,菲律宾70%的经济,都掌握在华裔手中.菲国内10大富豪有8位是祖籍福建的华人. 小编:菲律宾人对待金钱的态度很随意,没钱有没钱的快乐,你不懂--"寅吃卯粮& ...

  • [转载]人体隐秘的“医学真相”(二十五):真该骂niang!*

    人体隐秘的"医学真相"(二十五)真该骂niang!--"糖尿病"这个命名!一.陈旧的认识.可怕的真相.可怕的现实!

  • 素说《论语》:里仁篇(二十五)

    一原文里仁第四4.25 子曰:"德不孤,必有邻."[试解]孔老师说:"通达于仁德境界的人,能够自觉地将己身浸润于仁德之中,让自己的身心得到仁德的沐浴滋润,从而能够象母亲呵 ...