总结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调用Moxa PCOMM Lite通过串口Ymodem协议实现发送文件
Aug 15 Python
详解Python中break语句的用法
May 14 Python
Python中使用urllib2模块编写爬虫的简单上手示例
Jan 20 Python
最近Python有点火? 给你7个学习它的理由!
Jun 26 Python
基于python实现名片管理系统
Nov 30 Python
解决pandas .to_excel不覆盖已有sheet的问题
Dec 10 Python
为什么从Python 3.6开始字典有序并效率更高
Jul 15 Python
详解基于python-django框架的支付宝支付案例
Sep 23 Python
如何使用python的ctypes调用医保中心的dll动态库下载医保中心的账单
May 24 Python
Python自动创建Excel并获取内容
Sep 16 Python
python re模块和正则表达式
Mar 24 Python
Python合并多张图片成PDF
Jun 09 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 Array交叉表实现代码
2010/08/05 PHP
php后门URL的防范
2013/11/12 PHP
php+ajax制作无刷新留言板
2015/10/27 PHP
ThinkPHP5.1表单令牌Token失效问题的解决
2019/03/22 PHP
服务端 VBScript 与 JScript 几个相同特性的写法 By shawl.qiu
2007/03/06 Javascript
JS 字符串连接[性能比较]
2009/05/10 Javascript
JavaScript 事件查询综合
2009/07/13 Javascript
JQuery 学习笔记 选择器之三
2009/07/23 Javascript
Jquery中getJSON在asp.net中的使用说明
2011/03/10 Javascript
JS实现遮罩层效果的简单实例
2013/11/12 Javascript
禁止拷贝网页内容的js代码
2014/01/22 Javascript
使用jQuery时Form表单元素ID和name命名大忌
2014/03/06 Javascript
jQuery事件绑定与解除绑定实现方法
2015/04/15 Javascript
Zabbix添加Node.js监控的方法
2016/10/20 Javascript
Angular 2父子组件数据传递之@Input和@Output详解 (上)
2017/07/05 Javascript
使用 jQuery 实现表单验证功能
2017/07/05 jQuery
微信小程序实现折叠展开效果
2018/07/19 Javascript
使用JavaScript计算前一天和后一天的思路详解
2019/12/20 Javascript
简单了解JavaScript弹窗实现代码
2020/05/07 Javascript
关于Django外键赋值问题详解
2017/08/13 Python
python实现定时压缩指定文件夹发送邮件
2020/12/22 Python
Python 实现大整数乘法算法的示例代码
2019/09/17 Python
pytorch实现对输入超过三通道的数据进行训练
2020/01/15 Python
德国孕妇装和婴童服装网上商店:bellybutton
2018/04/12 全球购物
Calzedonia美国官网:意大利风格袜子、打底裤和沙滩装
2018/07/19 全球购物
经典c++面试题二
2015/08/14 面试题
介绍一下XMLHttpRequest对象
2012/02/12 面试题
法警的竞聘演讲稿
2014/01/02 职场文书
回门宴父母答谢词
2014/01/26 职场文书
2014年终工作总结范本
2014/12/15 职场文书
学生党员检讨书范文
2014/12/27 职场文书
银行客户经理岗位职责
2015/04/09 职场文书
初中体育课教学反思
2016/02/16 职场文书
导游词之泰山玉皇顶
2019/12/23 职场文书
微软官方消息,在 2023 年 4 月 11 日之后微软将不再为 Office 2013 和 Skype for Business 2015 提供安全更新
2022/04/21 数码科技
图神经网络GNN算法
2022/05/11 Python