前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【Python从入门到精通】(二十五)Python多进程的使用,一看就会

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

作者头像
码农飞哥
发布2021-10-08 15:33:34
1860
发布2021-10-08 15:33:34
举报
文章被收录于专栏:好好学习好好学习

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

前言

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

进程的创建

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

代码语言:javascript
复制
__init__(self, group=None, target=None, name=None, args=(), kwargs={})

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

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

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

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

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

name: 为新建进程设置名称

start() 方法用于启动进程

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

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

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

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

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

代码语言:javascript
复制
# 创建进程
process = Process(target=async_fun, args=("子进程", my_tuple))
# 启动子进程
process.start()
# 启动主进程
async_fun("主进程", my_tuple)
代码语言:javascript
复制
运行结果是:

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

代码语言:javascript
复制
这里需要注意的一点是,必须要将代码放在`if __name__ == '__main__':` 代码块中。通过os.getpid()方法来获取进程号。
#### 2.通过继承Process类的子类,创建实例对象,也可以创建新的进程。
第二种方式就是通过继承Process类的子类,创建实例对象,也可以创建新的进程,不过这种方式需要重写父类的run()方法。这种方法就类似于直接继承Thread类创建线程。
```py
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函数来创建进程池。

代码语言:javascript
复制
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()

运行结果是:

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

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

代码语言:javascript
复制
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))

运行结果是:

代码语言:javascript
复制
进程号:11726最大值是20
进程号:11725最大值是30
进程号:11727最大值是40
进程号:11728最大值是50

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

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

总结

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

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2021-09-12,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 码农飞哥 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 进程的创建
    • 进程池的使用
      • 多进程和多线程的优缺点对比
      • 总结
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档