Python 多进程和数据传递的理解

作者:wait_for_eva 时间:2021-06-01 02:30:07 

Python 多进程和数据传递的理解

python不仅线程用的是系统原生线程,进程也是用的原生进程

进程的用法和线程大同小异


import multiprocessing

p = multiprocessing.Process(target=fun,args=())

线程的基本方法在进程中都能够使用

但是进程和线程中有一个明显的区别:可以实现多核的运用

python本身会启动一个主进程,并且拥有一个主线程把主进程看做一家之主,那主线程也是他本身,其他线程就相当于老婆们
而进程,长大了的儿子们,线程固然是不能分割的,一家人还是要团结,但是儿子自家的事务,老子却也不能插手,所以,一家只能占用一个CPU实现单核运用的话,生多个儿子那必然就实现了多核运用

GIL锁住的,只是一个进程,让一家人团结

但是一个进程只有这么一把全量锁,线程不能单独跑,那就打包一起跑

多进程就这样完成了一般语言中多线程的优化

数据传递

多线程,多进程中总有要协同的工作,都涉及数据的交互,不过交互方式有些不同

信息进行传递的时候,为了不阻塞执行一般会将数据放入对列当中而不是直接返回

线程中,由于都属于同一个进程,定义一个全局的队列在各线程中就能够压入数据

进程可能运行在不同的CPU上,因此,相互间的传递不能在全局定义,只能通过创建时进行传入

内部操作:传入的队列实际上并不是将引用传入,然后直接操作队列,这毕竟是不同的CPU上的工作

队列的传入实际上是队列拷贝的传入,通过pickle拷贝后进行传入,然后再pickle将数据传回


import multiprocessing

multiprocessing.Queue()

线程和进程都有不同的队列对象,以实现不同的数据交互,不能错位使用

如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

来源:http://blog.csdn.net/wait_for_eva/article/details/78106322

标签:Python,多进程,数据传递
0
投稿

猜你喜欢

  • 对python:threading.Thread类的使用方法详解

    2022-01-24 04:19:28
  • Python趣味实例,实现一个简单的抽奖刮刮卡

    2023-07-20 18:59:41
  • 一文带你重温一下Python的对象模型

    2022-09-15 15:52:52
  • Javascript 动画初探(实现)

    2009-02-06 15:56:00
  • Access 2003开发者扩展工具集概述

    2009-03-19 18:32:00
  • 基于Python实现定时自动给微信好友发送天气预报

    2023-09-13 01:24:05
  • ACCESS中Field对象的标题属性

    2008-11-20 17:44:00
  • 系统默认的MySQL用户名消失的解决方法

    2008-12-02 14:26:00
  • python中return不返回值的问题解析

    2021-04-26 20:36:07
  • python实现人脸检测的简单实例

    2023-02-17 16:08:20
  • Python打印特殊符号及对应编码解析

    2023-08-16 02:14:07
  • 详解Python中的__getitem__方法与slice对象的切片操作

    2022-04-26 19:54:55
  • Symfony2框架创建项目与模板设置实例详解

    2023-11-20 23:36:39
  • ASP sql:rs.open语句详细说明

    2008-03-17 11:30:00
  • DW CS4初步试用感受

    2008-05-30 12:17:00
  • 好的产品设计并非始于图片,而是对人的理解

    2009-08-02 20:25:00
  • python转换字符串为摩尔斯电码的方法

    2022-01-01 10:17:44
  • Django框架中间件(Middleware)用法实例分析

    2021-01-04 09:27:38
  • MySQL数据库之UPDATE更新语句精解

    2009-03-20 15:21:00
  • 在SQL Server中使用索引的技巧

    2009-02-24 17:50:00
  • asp之家 网络编程 m.aspxhome.com