总结python多进程multiprocessing的相关知识


Posted in Python onJune 29, 2021

multiprocessing多进程

概念

总结python多进程multiprocessing的相关知识

创建多进程基本流程

总结python多进程multiprocessing的相关知识

创建进程对象

总结python多进程multiprocessing的相关知识

启动进程 回收进程

总结python多进程multiprocessing的相关知识

代码:

import multiprocessing as mp
from time import sleep

# 进程执行函数
def fun():
    print("开始一个进程")
    sleep(3)
    print("进程结束")

# 创建进程对象
p = mp.Process(target = fun)

p.start()   # 启动进程

p.join()    # 回收进程

运行结果:

开始一个进程
进程结束
Process finished with exit code 0

1 、父子进程是并行执行的 子进程执行函数 父进程执行除子进程外内容:

import multiprocessing as mp
from time import sleep

# 进程执行函数
def fun():
    print("开始一个进程")
    sleep(3)
    print("进程结束")

# 创建进程对象
p = mp.Process(target = fun)    # 把fun函数作为独立子进程 其它函数由进程来执行

p.start()   # 启动进程

sleep(2)
print("父进程执行内容")

p.join()    # 回收进程
print("===============")
"""
pid = os.fork
if pid == 0
    fun()
    os._exit(0)
else:
    os.wait()
"""

运行结果:

开始一个进程
父进程执行内容
进程结束

===============

2、子进程不能改变父进程中变量的值
代码:

import multiprocessing as mp
from time import sleep

a = 1

# 进程执行函数
def fun():
    print("开始一个进程")
    sleep(3)
    global a
    print("a=", a)
    a = 1000
    print("a=", a)
    print("进程结束")

# 创建进程对象
p = mp.Process(target = fun)    # 把fun函数作为独立子进程 其它函数由进程来执行

p.start()   # 启动进程

sleep(2)
print("父进程执行内容")

p.join()    # 回收进程
print("===============")
print("a=", a)

运行结果:

开始一个进程
父进程执行内容
a= 1
a= 1000
进程结束
a= 1

创建多个进程
代码:

"""
创建多个进程
"""

from multiprocessing import Process
import os
from time import sleep

def fun1():
    sleep(2)
    print(os.getppid(), '--', os.getpid(), "吃饭")

def fun2():
    sleep(3)
    print(os.getppid(), '--', os.getpid(), "睡觉")

def fun3():
    sleep(4)
    print(os.getppid(), '--', os.getpid(), "学习")

jobs =[]

for th in [fun1, fun2, fun3]:
    p = Process(target = th)
    jobs.append(p)
    p.start()

for i in jobs:
    i.join()

运行结果:

46013 ? 46022 吃饭
46013 ? 46023 睡觉
46013 ? 46024 学习

含有参数的进程函数
代码:

from multiprocessing import Process
from time import sleep

# 含有参数的进程函数
def worker(sec, name):
    for i in range(3):
        sleep(sec)
        print("I'm %s"%name)
        print("I'm working...")

# p = Process(target = worker, args = (2, "Tom"))
p = Process(target = worker, kwargs = {'name':'tom', 'sec': 2})

p.start()
p.join()

运行结果:

I'm tom
I'm working…
I'm tom
I'm working…
I'm tom
I'm working…

案例练习

总结python多进程multiprocessing的相关知识

代码:

from multiprocessing import Process
import os

filename = './dace.jpg'
size = os.path.getsize(filename)

# 复制上半部分
def up():
    fr = open(filename, 'rb')
    fw = open('bot,jpg', 'wb')
    n = size//2
    fw.write(fr.read(n))
    fw.close()
    fr.close()

# 复制下半部分
def down():
    fr = open(filename, 'rb')
    fw = open('bot,jpg', 'wb')
    fr.seek(size//2.0)
    fw.write(fr.read())
    fw.close()
    fr.close()

p = Process(target = up)
q = Process(target = down)
p.start()
q.start()
p.join()
q.join()

到此这篇关于总结python多进程multiprocessing的相关知识的文章就介绍到这了,更多相关python multiprocessing多进程内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
Python编程中对文件和存储器的读写示例
Jan 25 Python
基于python 字符编码的理解
Sep 02 Python
Python实现字符串反转的常用方法分析【4种方法】
Sep 30 Python
python登录并爬取淘宝信息代码示例
Dec 09 Python
python和opencv实现抠图
Jul 18 Python
python3 实现对图片进行局部切割的方法
Dec 05 Python
详解Python:面向对象编程
Apr 10 Python
Django框架自定义session处理操作示例
May 27 Python
Python3视频转字符动画的实例代码
Aug 29 Python
python实现查找所有程序的安装信息
Feb 18 Python
python GUI库图形界面开发之PyQt5菜单栏控件QMenuBar的详细使用方法与实例
Feb 28 Python
python 爬虫网页登陆的简单实现
Nov 30 Python
python 字典和列表嵌套用法详解
Jun 29 #Python
Python连接Postgres/Mysql/Mongo数据库基本操作大全
5行Python代码实现一键批量扣图
Python爬取用户观影数据并分析用户与电影之间的隐藏信息!
python geopandas读取、创建shapefile文件的方法
总结Pyinstaller打包的高级用法
Pandas数据类型之category的用法
Jun 28 #Python
You might like
PHP 七大优势分析
2009/06/23 PHP
WordPress中给文章添加自定义字段及后台编辑功能区域
2015/12/19 PHP
windows server 2008/2012安装php iis7 mysql环境搭建教程
2016/06/30 PHP
图片自动更新(说明)
2006/10/02 Javascript
Fastest way to build an HTML string(拼装html字符串的最快方法)
2011/08/20 Javascript
JavaScript拆分字符串时产生空字符的解决方案
2014/09/26 Javascript
JS获得选取checkbox整行数据的方法
2015/01/28 Javascript
jquery中ready()函数执行的时机和window的load事件比较
2015/06/22 Javascript
js实现网页收藏功能
2015/12/17 Javascript
原生JS实现网络彩票投注效果
2016/09/25 Javascript
Bootstrap基本组件学习笔记之按钮组(8)
2016/12/07 Javascript
干货!教大家如何选择Vue和React
2017/03/13 Javascript
vue使用keep-alive保持滚动条位置的实现方法
2019/04/09 Javascript
用webpack4开发小程序的实现方法
2019/06/04 Javascript
python命令行参数解析OptionParser类用法实例
2014/10/09 Python
Python实现简单多线程任务队列
2016/02/27 Python
浅谈插入排序算法在Python程序中的实现及简单改进
2016/05/04 Python
Python中的命令行参数解析工具之docopt详解
2017/03/27 Python
Python Pywavelet 小波阈值实例
2019/01/09 Python
django框架防止XSS注入的方法分析
2019/06/21 Python
python 怎样将dataframe中的字符串日期转化为日期的方法
2019/09/26 Python
Python 元组拆包示例(Tuple Unpacking)
2019/12/24 Python
Python3.7安装pyaudio教程解析
2020/07/24 Python
英国和国际包裹递送:ParcelCompare
2019/08/26 全球购物
小学毕业感言50字
2014/02/16 职场文书
公职人员索取回扣检举信
2014/04/04 职场文书
2014年五一劳动节社区活动总结
2014/04/14 职场文书
竞选副班长演讲稿
2014/04/24 职场文书
镇班子对照检查材料思想汇报
2014/09/24 职场文书
2015年高一班主任工作总结
2015/05/13 职场文书
高温慰问简报
2015/07/21 职场文书
药房管理制度范本
2015/08/06 职场文书
升职自荐书
2019/05/09 职场文书
关于python pygame游戏进行声音添加的技巧
2021/10/24 Python
Java 深入探究讲解简单工厂模式
2022/04/07 Java/Android
使用CSS实现百叶窗效果示例代码
2023/05/07 HTML / CSS